start-hello.md 8.43 KB
Newer Older
1
Diciendo Hola
2
=============
3

4 5 6
Esta sección describe cómo crear la típica página "Hola Mundo" (Hello World en inglés) en tu aplicación.
Para lograr este objetivo, vas a crear una [acción](structure-controllers.md#creating-actions) y 
una [vista](structure-views.md):
7 8 9 10 11 12

* La aplicación enviará la petición de la página a la acción
* y la acción regresará el render de la vista que muestra la palabra "Hola" al usuario final.

A lo largo de este tutorial, aprenderás tres cosas:

13
1. Cómo crear una [acción](structure-controllers.md) para responder peticiones (request),
Antonio Ramirez committed
14 15
2. Cómo crear una [vista](structure-views.md) para armar el contenido de la respuesta, y
3. Cómo una aplicación envía peticiones a las [acciones](structure-controllers.md#creating-actions).
16 17 18 19 20


Creando una Acción <a name="creating-action"></a>
------------------

21
Para la tarea "Hola", crearás una [acción](structure-controllers.md#creating-actions) `say` que lee
22 23
un parámetro `message` de la petición y muestra este mensaje de vuelta al usuario. Si la petición
no provee un parámetro `message`, la acción mostrará el mensaje por defecto "Hola".
24

25 26
> Información: Las [acciones](structure-controllers.md#creating-actions) son objetos que los usuarios finales pueden utilizar directamente para
  su ejecución. Las acciones están agrupadas por [controladores](structure-controllers.md) (controllers). El resultado de la ejecución de
27 28
  una acción es la respuesta que el usuario final recibirá.

29 30
Las acciones deben ser declaradas en [controladores](structure-controllers.md). Para simplificar, puedes
declarar la acción `say` en el controlador `SiteController` existente. Este controlador está definido
31 32 33 34 35 36 37 38 39 40 41 42 43
en el archivo de clase `controllers/SiteController.php`. Aquí está el inicio de la nueva acción:

```php
<?php

namespace app\controllers;

use yii\web\Controller;

class SiteController extends Controller
{
    // ...código existente...

44
    public function actionSay($message = 'Hola')
45
    {
46
        return $this->render('say', ['message' => $message]);
47 48 49 50
    }
}
```

51
En el código de arriba, la acción `say` está definida por un método llamado `actionSay` en la clase `SiteController`.
52 53 54 55 56
Yii utiliza el prefijo `action` para diferenciar los métodos de acciones de otros métodos en las clases de los controladores.
El nombre que le sigue al prefijo `action` se mapea al ID de la acción.

Cuando se trata de nombrar las acciones, debes entender como Yii trata los ID de las acciones. Los ID de las acciones siempre son 
referenciados en minúscula. Si un ID de acción requiere múltiples palabras, estas serán concatenadas con guiones
57
(ej., `crear-comentario`). Los nombres de los métodos de las acciones son mapeados a los ID de las acciones 
58 59 60
removiendo los guiones, colocando en mayúscula la primera letra de cada palabra, y colocando el prefijo `action` al resultado. Por ejemplo,
el ID de la acción `crear-comentario` corresponde al nombre de método de acción `actionCrearComentario`.

61
El método de acción en nuestro ejemplo toma un parámetro `$message`, el cual tiene como valor por defecto `"Hola"` (de la misma manera 
62
que se coloca un valor por defecto a un argumento en cualquier función o método en PHP). Cuando una aplicación 
63
recibe una petición y determina que la acción `say` es responsable de manejar dicha petición, la aplicación llenará 
64
el parámetro con el parámetro que tenga el mismo nombre en la petición. En otras palabras, si la petición incluye un 
65
parámetro `message` con el valor de `"Adios"`, la variable `$message` dentro de la acción será sustituida por este valor.
66 67

Dentro del método de acción, [[yii\web\Controller::render()|render()]] es llamado para hacer render (mostrar o visualizar) un 
68
archivo [vista](structure-views.md) (template) llamado `say`. El parámetro `message` tambien es pasado al  view para que pueda ser utilizado ahí. 
Antonio Ramirez committed
69
El resultado es devuelto al método de la acción. Ese resultado será recibido por la aplicación y mostrado al usuario final en el
70 71 72 73 74 75
navegador (como parte de una página HTML completa).


Creando una Vista <a name="creating-view"></a>
-----------------

76
Las [vistas](structure-views.md) son scripts que escribes para generar una respuesta de contenido.
77
Para la tarea "Hola", vas a crear una vista `say` que imprime el parámetro `message` recibido desde el método action, y pasado por la acción a la vista:
78 79 80 81 82

```php
<?php
use yii\helpers\Html;
?>
83
<?= Html::encode($message) ?>
84 85
```

Antonio Ramirez committed
86
La vista `say` debe ser guardada en el archivo `views/site/say.php`. Cuando el método [[yii\web\Controller::render()|render()]]
87
es llamado en una acción, buscará un archivo PHP llamado `views/ControllerID/NombreVista.php`.
88

89
Nota que en el código de arriba, el parámetro `message` es procesado por [[yii\helpers\Html::encode()|HTML-encoded]]
90 91 92
antes de ser impreso. Esto es necesario ya que el parámetro viene de un usuario final, haciéndolo vulnerable a 
[ataques cross-site scripting (XSS)](http://es.wikipedia.org/wiki/Cross-site_scripting) pudiendo inyectar código de Javascript malicioso dentro del parámetro.

Antonio Ramirez committed
93
Naturalmente, puedes colocar mas contenido en la vista `say`. El contenido puede consistir de etiquetas HTML, texto plano, e inclusive código PHP.
94 95
De hecho, la vista `say` es sólo un script PHP que es ejecutado por el método [[yii\web\Controller::render()|render()]].
El contenido impreso por el script de la vista será regresado a la aplicación como la respuesta del resultado. La aplicación a cambio mostrará el resultado al usuario final.
96 97


Antonio Ramirez committed
98 99
Probándolo <a name="trying-it-out"></a>
----------
100

101
Después de crear la acción y la vista, puedes acceder a la nueva página abriendo el siguiente URL:
102 103

```
104
http://hostname/index.php?r=site/say&mensaje=Hello+World
105 106 107 108 109 110
```

![Hello World](images/start-hello-world.png)

Esta URL resultará en una página mostrando "Hello World". La página comparte el mismo encabezado y pie de página de las otras páginas de la aplicación. 

111 112
Si omites el parámetro `message` en el URL, verás que la página muestra sólo "Hola". Esto es porque `message` es pasado como un parámetro al método `actionSay()`, 
y cuando es omitido, el valor por defecto `"Hola"` será utilizado.
113

114 115
> Información: La nueva página comparte el mismo encabezado y pie de página que otras páginas porque el método [[yii\web\Controller::render()|render()]]
  automáticamente inyectará el resultado de la vista `say` en el [layout](structure-views.md#layouts), que en este 
116 117
  caso está localizada en `views/layouts/main.php`.

118 119 120 121 122 123
El parámetro `r` en el URL de arriba requiere más explicación. Se refierea a [route](runtime-routing.md) (ruta), y es el ID amplio y único de una aplicación
que refiere a una acción. El formato de las rutas es `ControllerID/ActionID`. Cuando la aplicación recibe una petición, revisará este parámetro,
utilizando la parte del `ControllerID` para determinar cual clase de controlador será inicializado para manejar la petición. Entonces, el controlador utilizará
la parte `ActionID` para determinar cual acción debe ser inizializada para hacer realmente el trabajo. 
En este ejemplo, la ruta  `site/say` será respondida por la clase controlador `SiteController` y la acción `say`. Como resultado, 
el método `SiteController::actionSay()` será llamado para manejar el requerimiento.
124

125 126 127
> Información: Al igual que las acciones, los controladores tambien tienen ID únicos que los identifican en una aplicación.
  Los ID de los Controladores utilizan las mismas reglas de nombrado que los ID de las acciones. Los nombres de las clases de los controladores son derivados de los ID de los controladores removiendo los guiones de los ID, colocando la primera letra en mayúscula en cada palabra, y colocando el sufijo `Controller` al resultado. Por ejemplo, el ID del controlador `post-comentario` corresponde
  al nombre de clase del controlador `PostComentarioController`.
128 129 130 131 132 133


Resumen <a name="summary"></a>
-------

En esta sección, has tocado las partes del controlador y la vista del patrón de diseño MVC.
134 135
Has creado una acción como parte de un controlador para manejar una petición específica. Y también has creado una vista para armar el contenido de la respuesta. 
En este simple ejemplo, ningún modelo ha sido involucrado ya que el único dato que fue utilizado fue el parámetro `message`.
136 137 138 139

También has aprendido acerca de las rutas en Yii, que actúan como puentes entre la petición del usuario y las acciones del controlador.

En la próxima sección, aprenderás como crear un modelo, y agregar una nueva página que contenga un formulario HTML.