This section describes how to create a new "Hello" page in your application.
This section describes how to create a new "Hello" page in your application.
To achieve this goal, you will create an [action](structure-controllers.md) and
To achieve this goal, you will create an [action](structure-controllers.md#creating-actions) and
a [view](structure-views.md):
a [view](structure-views.md):
* The application will dispatch the page request to the action
* The application will dispatch the page request to the action
*And the action will in turn render the view that shows "Hello" to the end user
*and the action will in turn render the view that shows the word "Hello" to the end user.
Through this tutorial, you will learn how:
Through this tutorial, you will learn three things:
* To create an [action](structure-controllers.md) to respond to requests
1. How to create an [action](structure-controllers.md) to respond to requests,
* To create a [view](structure-views.md) to compose the response's content
2. how to create a [view](structure-views.md) to compose the response's content, and
* An application dispatches requests to [actions](structure-controllers.md)
3. how an application dispatches requests to [actions](structure-controllers.md#creating-actions).
Creating an Action <a name="creating-action"></a>
Creating an Action <a name="creating-action"></a>
------------------
------------------
For the "Hello" task, you will create a `say`[action](structure-controllers.md) that reads
For the "Hello" task, you will create a `say`[action](structure-controllers.md#creating-actions) that reads
a `message` parameter from the request and displays that message back to the user. If the request
a `message` parameter from the request and displays that message back to the user. If the request
does not provide a `message` parameter, the action will display the default "Hello" message.
does not provide a `message` parameter, the action will display the default "Hello" message.
> Info: [Actions](structure-controllers.md) are the objects that end users can directly refer to for
> Info: [Actions](structure-controllers.md#creating-actions) are the objects that end users can directly refer to for
execution. Actions are grouped by [controllers](structure-controllers.md). The execution result of
execution. Actions are grouped by [controllers](structure-controllers.md). The execution result of
an action is the response that an end user will receive.
an action is the response that an end user will receive.
...
@@ -48,17 +48,21 @@ class SiteController extends Controller
...
@@ -48,17 +48,21 @@ class SiteController extends Controller
}
}
```
```
In the above code, the `say` action is defined as a method named `actionSay` in `SiteController`.
In the above code, the `say` action is defined as a method named `actionSay` in the `SiteController` class.
Yii uses the prefix `action` to differentiate action methods from non-action methods in a controller class.
Yii uses the prefix `action` to differentiate action methods from non-action methods in a controller class.
The name after the `action` prefix is maps to the action's ID.
The name after the `action` prefix maps to the action's ID.
When it comes to naming your actions, you should understand how Yii treats action IDs. Action IDs are always referenced in lower case. If an action ID requires multiple words, they will be concatenated by dashes (e.g., `create-comment`). Action method names are mapped to action IDs by removing any dashes from the IDs,
When it comes to naming your actions, you should understand how Yii treats action IDs. Action IDs are always
capitalizing the first letter in each word, and prefixing the resulting with `action`. For example,
referenced in lower case. If an action ID requires multiple words, they will be concatenated by dashes
the action ID `create-comment` corresponds to the action method name `actionCreateComment`.
(e.g., `create-comment`). Action method names are mapped to action IDs by removing any dashes from the IDs,
capitalizing the first letter in each word, and prefixing the resulting with `action`. For example,
the action ID `create-comment` corresponds to the action method name `actionCreateComment`.
The action method takes a parameter `$message`, whose value defaults to `"Hello"` (in exatly the same way you set a default value for any function or method argument in PHP). When the application
The action method in our example takes a parameter `$message`, whose value defaults to `"Hello"` (in exactly
the same way you set a default value for any function or method argument in PHP). When the application
receives a request and determines that the `say` action is responsible for handling said request, the application will
receives a request and determines that the `say` action is responsible for handling said request, the application will
populate this parameter with the same named parameter found in the request. In other words, if the request includes a `message` paremter with a value of `"Goodbye"`, the $message variable within the action will be assigned that value.
populate this parameter with the same named parameter found in the request. In other words, if the request includes
a `message` parameter with a value of `"Goodbye"`, the `$message` variable within the action will be assigned that value.
Within the action method, [[yii\web\Controller::render()|render()]] is called to render
Within the action method, [[yii\web\Controller::render()|render()]] is called to render
a [view](structure-views.md) file named `say`. The `message` parameter is also passed to the view
a [view](structure-views.md) file named `say`. The `message` parameter is also passed to the view
...
@@ -80,7 +84,7 @@ use yii\helpers\Html;
...
@@ -80,7 +84,7 @@ use yii\helpers\Html;
```
```
The `say` view should be saved in the file `views/site/say.php`. When the method [[yii\web\Controller::render()|render()]]
The `say` view should be saved in the file `views/site/say.php`. When the method [[yii\web\Controller::render()|render()]]
is called in an action, it will look for a PHP file named as `views/ControllerID/ActionID/ViewName.php`.
is called in an action, it will look for a PHP file named as `views/ControllerID/ViewName.php`.
Note that in the above code, the `message` parameter is [[yii\helpers\Html::encode()|HTML-encoded]]
Note that in the above code, the `message` parameter is [[yii\helpers\Html::encode()|HTML-encoded]]
before being printed. This is necessary as the parameter comes from an end user, making it vulnerable to
before being printed. This is necessary as the parameter comes from an end user, making it vulnerable to
...
@@ -95,7 +99,7 @@ The content printed by the view script will be returned to the application as th
...
@@ -95,7 +99,7 @@ The content printed by the view script will be returned to the application as th
Trying it Out <a name="trying-it-out"></a>
Trying it Out <a name="trying-it-out"></a>
-------------
-------------
After creating the action and the view, you may access the new page by the following URL:
After creating the action and the view, you may access the new page by accessing the following URL:
After installing Yii, you have a working Yii application that can be accessed via the URL `http://hostname/basic/web/index.php` or `http://hostname/index.php`, depending upon your configuration. This section will introduce the application's built-in fucntionality, how the code is organized,
After installing Yii, you have a working Yii application that can be accessed via
and how the application handles requests in general.
the URL `http://hostname/basic/web/index.php` or `http://hostname/index.php`, depending
upon your configuration. This section will introduce the application's built-in functionality,
how the code is organized, and how the application handles requests in general.
> Info: For simplicity, throughout this "Getting Started" tutorial, it's assumed that you have set `basic/web`
> Info: For simplicity, throughout this "Getting Started" tutorial, it's assumed that you have set `basic/web`
as the document root of your Web server, and configured, the URL for accessing
as the document root of your Web server, and configured, the URL for accessing
...
@@ -11,14 +13,14 @@ and how the application handles requests in general.
...
@@ -11,14 +13,14 @@ and how the application handles requests in general.
Functionality <a name="functionality"></a>
Functionality <a name="functionality"></a>
---------------
-------------
The basic application installed contains four pages:
The basic application installed contains four pages:
*the homepage, displayed when you access the URL `http://hostname/index.php`
*The homepage, displayed when you access the URL `http://hostname/index.php`,
* the "About" page
* the "About" page,
* the "Contact" page displays a contact form that allows end users to contact you via email
* the "Contact" page, which displays a contact form that allows end users to contact you via email,
*the "Login" page displays a login form that can be used to authenticate end users. Try logging in
*and the "Login" page, which displays a login form that can be used to authenticate end users. Try logging in
with "admin/admin", and you will find the "Login" main menu item will change to "Logout".
with "admin/admin", and you will find the "Login" main menu item will change to "Logout".
These pages share a common header and footer. The header contains a main menu bar to allow navigation
These pages share a common header and footer. The header contains a main menu bar to allow navigation
...
@@ -46,13 +48,13 @@ basic/ application base path
...
@@ -46,13 +48,13 @@ basic/ application base path
vendor/ contains the installed Composer packages, including the Yii framework itself
vendor/ contains the installed Composer packages, including the Yii framework itself
views/ contains view files
views/ contains view files
web/ application Web root, contains Web accessible files
web/ application Web root, contains Web accessible files
assets/ contains published asset files (js, css) by Yii
assets/ contains published asset files (javascript and css) by Yii
index.php the entry (or bootstrap) script for the application
index.php the entry (or bootstrap) script for the application
yii the Yii console command execution script
yii the Yii console command execution script
```
```
In general, the files in the application can be divided into two types: those under `basic/web` and those
In general, the files in the application can be divided into two types: those under `basic/web` and those
under other directories. The former can be directly accessed from via HTTP (i.e., in a browser), while the latter can not and should not be.
under other directories. The former can be directly accessed via HTTP (i.e., in a browser), while the latter can not and should not be.
Yii implements the [model-view-controller (MVC)](http://wikipedia.org/wiki/Model-view-controller) design pattern,
Yii implements the [model-view-controller (MVC)](http://wikipedia.org/wiki/Model-view-controller) design pattern,
which is reflected in the above directory organization. The `models` directory contains all [model classes](structure-models.md),
which is reflected in the above directory organization. The `models` directory contains all [model classes](structure-models.md),