My homepage (or welcome page) will consist of data from two models (lets call them authors and posts). I am new to rails and not sure what is the best way to accomplish this.
Should I create a new controller called welcome which gathers data from the authors and posts and then display them in the welcome index view? Or should I have a welcome view under the post model which also gets data from authors? Or any other way to accomplish this?
I understand how to do all this technically but just unsure what is the best practice method using the rails framework.
Ruby on Rails Best Practice: Keep Your Code DRY Ruby on Rails' object-oriented principles are built to help you avoid duplicating code throughout your web application. Whenever possible, a great Ruby on Rails tip is to re-use as much code as possible instead of repeating similar code in many places.
Ruby's and Ruby on Rails' Overall Popularity Although way behind main contenders, such as PHP or Python, Ruby still makes the cut for the 20 most popular programming languages list in 2022. The 2022 edition of Stack Overflow Annual Developer Survey also places RoR in a similar spot.
In Rails, a RESTful route provides a mapping between HTTP verbs, controller actions, and (implicitly) CRUD operations in a database. A single entry in the routing file, such as. map.resources :photos. creates seven different routes in your application: HTTP verb.
There doesn't seem to be a single best practice.
(1) The standard config/routes.rb
file seems to suggest that the root page (or home/welcome page) should be handled by welcome#index
. If you were to be guided by that, then to generate the corresponding welcome#index
controller/action, you can use the following command:
rails generate controller Welcome index
Then, in config/routes.rb
, you can remove the GET route (get "welcome/index"
) automatically added by the generator, and place the root route root 'welcome#index'
(or root :to => 'welcome#index'
in Rails < 4
) at the top of the file, because it will probably be your most popular route and should be matched first.
Also remember to delete public/index.html
in Rails < 4
.
(2) The official Ruby on Rails routing guide uses PagesController
. It actually suggests pages#main
, though to me it makes more sense to go with pages#home
(because "homepage" is the ubiquitous term/concept). Additionally, this controller can handle other page-oriented actions such as pages#about
, pages#contact
, pages#terms
, pages#privacy
, etc.
(3) The Ruby on Rails Tutorial, goes with static_pages#home
and static_pages#help
, etc., though I don't like the idea of denoting this controller with "static". These pages will still likely have some dynamic aspects to them, particularly the homepage!
(4) Though it does not discuss how to handle a homepage, RailsCast #117 on Semi-Static Pages suggests yet another set of approaches to show-only resources.
I feel preference toward 1 and/or 2. With the "and" scenario, you could use welcome#index and pages#about, etc., whereas with the "or" scenario, you could use pages#home, pages#about, etc. If forced to choose, I would go with option 2 just because you end up with less code. And btw, 2 and 3 are pretty much the same, apart from the word "static".
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With