Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Y
yii2
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
PSDI Army
yii2
Commits
e8f092d6
Commit
e8f092d6
authored
Jun 27, 2014
by
Antonio Ramirez
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update structure-controllers.md
parent
db45f050
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
17 additions
and
17 deletions
+17
-17
structure-controllers.md
docs/guide-es/structure-controllers.md
+17
-17
No files found.
docs/guide-es/structure-controllers.md
View file @
e8f092d6
...
@@ -2,10 +2,10 @@ Controladores
...
@@ -2,10 +2,10 @@ Controladores
=============
=============
Los controladores son parte del patrón o arquitectura
[
MVC
](
http://es.wikipedia.org/wiki/Modelo%E2%80%93vista%E2%80%93controlador
)
.
Los controladores son parte del patrón o arquitectura
[
MVC
](
http://es.wikipedia.org/wiki/Modelo%E2%80%93vista%E2%80%93controlador
)
.
Son objetos que extienden de
[
[yii\base\Controller
]
] y se encargan de procesar los
`requests`
Son objetos que extienden de
[
[yii\base\Controller
]
] y se encargan de procesar los
`requests`
(consultas)
generando
`responses`
. En particular
, después de tomar el control desde las
[
aplicaciones
](
structure-applications.md
)
,
generando
`responses`
(respuestas). Particularmente
, después de tomar el control desde las
[
aplicaciones
](
structure-applications.md
)
,
los controladores analizarán los datos que entran en el
request
, los pasan a los
[
modelos
](
structure-models.md
)
, inyectan los
los controladores analizarán los datos que entran en el
`request`
, los pasan a los
[
modelos
](
structure-models.md
)
, inyectan los
modelos resultantes a las
[
vistas
](
structure-views.md
)
, y finalmente generan los
`responses`
de salida.
modelos resultantes a las
[
vistas
](
structure-views.md
)
, y finalmente generan los
`responses`
(respuestas)
de salida.
## Acciones <a name="actions"></a>
## Acciones <a name="actions"></a>
...
@@ -107,7 +107,7 @@ class SiteController extends Controller
...
@@ -107,7 +107,7 @@ class SiteController extends Controller
### IDs de Controladores <a name="controller-ids"></a>
### IDs de Controladores <a name="controller-ids"></a>
Usu
almente, un controlador está diseñado para manejar los
`requests`
de acuerdo a un tipo de recurso.
Norm
almente, un controlador está diseñado para manejar los
`requests`
de acuerdo a un tipo de recurso.
Por esta razón, los IDs de controladores son a menudo sustantivos de los tipos de recurso que están manejando.
Por esta razón, los IDs de controladores son a menudo sustantivos de los tipos de recurso que están manejando.
Por ejemplo, podrías utilizar
`article`
como el ID de un controlador que maneja datos de artículos.
Por ejemplo, podrías utilizar
`article`
como el ID de un controlador que maneja datos de artículos.
...
@@ -115,21 +115,21 @@ Por defecto, los IDs de controladores deberían contener sólo estos caracteres:
...
@@ -115,21 +115,21 @@ Por defecto, los IDs de controladores deberían contener sólo estos caracteres:
guiones bajos y medios, y barras. Por ejemplo,
`article`
,
`post-comment`
,
`admin/post2-comment`
son todos
guiones bajos y medios, y barras. Por ejemplo,
`article`
,
`post-comment`
,
`admin/post2-comment`
son todos
IDs de controladores válidos, mientras que
`article?`
,
`PostComment`
,
`admin\post`
no lo son.
IDs de controladores válidos, mientras que
`article?`
,
`PostComment`
,
`admin\post`
no lo son.
Los guiones en un ID de controlador son utilizados para separa
palabras, mientras que las barras para organizar los controladores
Los guiones en un ID de controlador son utilizados para separa
r palabras, mientras que las barras diagonales lo son para
en sub-directorios.
organizar los controladores
en sub-directorios.
### Nombres de Clases de Controladores <a name="controller-class-naming"></a>
### Nombres de Clases de Controladores <a name="controller-class-naming"></a>
Los nombre de clases de controladores pueden ser derivados de los IDs de acuerdo a las siguientes reglas:
Los nombre
s
de clases de controladores pueden ser derivados de los IDs de acuerdo a las siguientes reglas:
*
Transforma la primera letra de cada palabra separada por guiones en mayúscula. Nota que si el ID del controlador
*
Transforma la primera letra de cada palabra separada por guiones en mayúscula. Nota que si el ID del controlador
contiene barras, esta regla sólo aplica a la porción después de la última barra dentro del ID.
contiene barras, esta regla sólo aplica a la porción después de la última barra dentro del ID.
*
Elimina guiones y reemplaza cualquier barra por barras invertidas.
*
Elimina guiones y reemplaza cualquier barra
diagonal
por barras invertidas.
*
Agrega el sufijo
`Controller`
.
*
Agrega el sufijo
`Controller`
.
*
Agrega al principio el
[
[yii\base\Application::controllerNamespace|controller namespace
]
].
*
Agrega al principio el
[
[yii\base\Application::controllerNamespace|controller namespace
]
].
Los siguientes son algunos ejemplo
, asumiendo que el
[
[yii\base\Application::controllerNamespace|controller namespace
]
]
A continuación mostramos algunos ejemplos
, asumiendo que el
[
[yii\base\Application::controllerNamespace|controller namespace
]
]
toma el valor por defecto:
`app\controllers`
:
toma el valor por defecto:
`app\controllers`
:
*
`article`
deriva en
`app\controllers\ArticleController`
;
*
`article`
deriva en
`app\controllers\ArticleController`
;
...
@@ -141,7 +141,7 @@ la clase del controlador `article` debe ser guardada en un archivo cuyo alias [a
...
@@ -141,7 +141,7 @@ la clase del controlador `article` debe ser guardada en un archivo cuyo alias [a
es
`@app/controllers/ArticleController.php`
; mientras que el controlador
`admin/post2-comment`
debería estar
es
`@app/controllers/ArticleController.php`
; mientras que el controlador
`admin/post2-comment`
debería estar
en
`@app/controllers/admin/Post2CommentController.php`
.
en
`@app/controllers/admin/Post2CommentController.php`
.
> Información: El último ejemplo, `admin/post2-comment`, demuestra cómo puedes poner un controlador bajo un sub-directorio
> Información: E
n e
l último ejemplo, `admin/post2-comment`, demuestra cómo puedes poner un controlador bajo un sub-directorio
del
[
[yii\base\Application::controllerNamespace|controller namespace
]
]. Esto es útil cuando quieres organizar
del
[
[yii\base\Application::controllerNamespace|controller namespace
]
]. Esto es útil cuando quieres organizar
tus controladores en varias categorías pero sin utilizar
[
módulos
](
structure-modules.md
)
.
tus controladores en varias categorías pero sin utilizar
[
módulos
](
structure-modules.md
)
.
...
@@ -150,7 +150,7 @@ en `@app/controllers/admin/Post2CommentController.php`.
...
@@ -150,7 +150,7 @@ en `@app/controllers/admin/Post2CommentController.php`.
Puedes configurar
[
[yii\base\Application::controllerMap|controller map
]
] (mapeo de controladores) para superar las restricciones
Puedes configurar
[
[yii\base\Application::controllerMap|controller map
]
] (mapeo de controladores) para superar las restricciones
de los IDs de controladores y sus nombres de clase descritos arriba. Esto es principalmente útil cuando estás utilizando un
de los IDs de controladores y sus nombres de clase descritos arriba. Esto es principalmente útil cuando estás utilizando un
controlador de terceros del cual no tiene
control
sobre sus nombres de clase.
controlador de terceros del cual no tiene
s control alguno
sobre sus nombres de clase.
Puedes configurar
[
[yii\base\Application::controllerMap|controller map
]
] en la
Puedes configurar
[
[yii\base\Application::controllerMap|controller map
]
] en la
[
configuración de la aplicación
](
structure-applications.md#application-configurations
)
de la siguiente manera:
[
configuración de la aplicación
](
structure-applications.md#application-configurations
)
de la siguiente manera:
...
@@ -226,14 +226,14 @@ guiones bajos y barras. Los guiones en un ID de acción son utilizados para sepa
...
@@ -226,14 +226,14 @@ guiones bajos y barras. Los guiones en un ID de acción son utilizados para sepa
Puedes crear acciones de dos maneras: acciones en línea (inline) o acciones independientes (standalone). Una acción en línea
Puedes crear acciones de dos maneras: acciones en línea (inline) o acciones independientes (standalone). Una acción en línea
es definida como un método en la clase del controlador, mientras que una acción independiente es una clase que extiende
es definida como un método en la clase del controlador, mientras que una acción independiente es una clase que extiende
[
[yii\base\Action
]
] o sus clases hijas.
A
cciones en línea son más fáciles de crear y por lo tanto preferidas
[
[yii\base\Action
]
] o sus clases hijas.
Las a
cciones en línea son más fáciles de crear y por lo tanto preferidas
si no tienes intenciones de volver a utilizarlas. Las acciones independientes, por otro lado, son principalmente
si no tienes intenciones de volver a utilizarlas. Las acciones independientes, por otro lado, son principalmente
creadas para ser reutilizadas en otros controladores o ser redistribuidas como
[
extensiones
](
structure-extensions.md
)
.
creadas para ser reutilizadas en otros controladores o
para
ser redistribuidas como
[
extensiones
](
structure-extensions.md
)
.
### Acciones en Línea <a name="inline-actions"></a>
### Acciones en Línea <a name="inline-actions"></a>
Acciones en línea se refieren a acciones que son definidas en términos de métodos como se acaba
de describir.
Como acciones en línea nos referimos a acciones que son definidas en términos de métodos como acabamos
de describir.
Los nombre de métodos de acciones derivan de los IDs de acuerdo al siguiente criterio:
Los nombre de métodos de acciones derivan de los IDs de acuerdo al siguiente criterio:
...
@@ -243,7 +243,7 @@ Los nombre de métodos de acciones derivan de los IDs de acuerdo al siguiente cr
...
@@ -243,7 +243,7 @@ Los nombre de métodos de acciones derivan de los IDs de acuerdo al siguiente cr
Por ejemplo,
`index`
se vuelve
`actionIndex`
, y
`hello-world`
se vuelve
`actionHelloWorld`
.
Por ejemplo,
`index`
se vuelve
`actionIndex`
, y
`hello-world`
se vuelve
`actionHelloWorld`
.
> Nota: Los nombre de los métodos de acción son *case-sensitive* (distinguen entre minúsculas y mayúsculas). Si tienes un
> Nota: Los nombre
s
de los métodos de acción son *case-sensitive* (distinguen entre minúsculas y mayúsculas). Si tienes un
método llamado
`ActionIndex`
, no será considerado como un método de acción, y como resultado, solicitar la acción
`index`
método llamado
`ActionIndex`
, no será considerado como un método de acción, y como resultado, solicitar la acción
`index`
resultará en una excepción. También ten en cuenta que los métodos de acción deben ser
`public`
. Un método
`private`
o
`protected`
resultará en una excepción. También ten en cuenta que los métodos de acción deben ser
`public`
. Un método
`private`
o
`protected`
NO define un método de acción.
NO define un método de acción.
...
@@ -410,7 +410,7 @@ class SiteController extends Controller
...
@@ -410,7 +410,7 @@ class SiteController extends Controller
## Ciclo de Vida del Controlador <a name="controller-lifecycle"></a>
## Ciclo de Vida del Controlador <a name="controller-lifecycle"></a>
Cuando se procesa un
`request`
, la
[
aplicación
](
structure-applications.md
)
creará un controlador
Cuando se procesa un
`request`
, la
[
aplicación
](
structure-applications.md
)
creará un controlador
basad
a
en la
[
ruta
](
#routes
)
solicitada. El controlador entonces irá a través del siguiente ciclo de vida
basad
o
en la
[
ruta
](
#routes
)
solicitada. El controlador entonces irá a través del siguiente ciclo de vida
para completar el
`request`
:
para completar el
`request`
:
1.
El método
[
[yii\base\Controller::init()
]
] es llamado después de que el controlador es creado y configurado.
1.
El método
[
[yii\base\Controller::init()
]
] es llamado después de que el controlador es creado y configurado.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment