aboutsummaryrefslogtreecommitdiffstats
path: root/railties/doc/guides/source/actioncontroller_basics/methods.txt
blob: 370b492e412df1887d711edd1102d18f01285b66 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
== Methods and actions ==

A controller is a Ruby class which inherits from ActionController::Base and has methods just like any other class. Usually these methods correspond to actions in MVC, but they can just as well be helpful methods which can be called by actions. When your application receives a request, the routing will determine which controller and action to run. Then an instance of that controller will be created and the method corresponding to the action (the method with the same name as the action) gets run.

[source, ruby]
----------------------------------------------
class ClientsController < ActionController::Base

  # Actions are public methods
  def new
  end

  # These methods are responsible for producing output
  def edit
  end

# Helper methods are private and can not be used as actions
private

  def foo
  end

end
----------------------------------------------

Private methods in a controller are also used as filters, which will be covered later in this guide.

As an example, if the user goes to `/clients/new` in your application to add a new client, a ClientsController instance will be created and the `new` method will be run. Note that the empty method from the example above could work just fine because Rails will by default render the `new.html.erb` view unless the action says otherwise. The `new` method could make available to the view a `@client` instance variable by creating a new Client:

[source, ruby]
----------------------------------------------
def new
  @client = Client.new
end
----------------------------------------------

The link:../layouts_and_rendering.html[Layouts & rendering guide] explains this in more detail.