Controladores de AngularJS
- Página anterior Vínculos de datos de AngularJS
- Página siguiente Scope de AngularJS
Controladores de AngularJS控制 AngularJS 应用程序的数据。
AngularJS 控制器是常规的 JavaScript 对象。
Controladores de AngularJS
AngularJS 应用程序由控制器控制。
ng-controller 指令定义应用程序控制器。
控制器是由标准的 JavaScript 对象构造器创建的 JavaScript 对象。
Ejemplos de AngularJS
<div ng-app="myApp" ng-controller="myCtrl"> Nombre: <input type="text" ng-model="firstName"><br> Apellido: <input type="text" ng-model="lastName"><br> <br> 全名: {{firstName + " " + lastName}} </div> <script> var app = angular.module('myApp', []); app.controller('myCtrl', function($scope) { $scope.firstName = "Bill"; $scope.lastName = "Gates"; }); </script>
应用程序说明:
AngularJS 应用程序由 ng-app="myApp"
定义。应用程序在 <div> 内运行。
ng-controller="myCtrl"
Una propiedad es una directiva AngularJS. Define un controlador.
myCtrl
Una función es una función JavaScript.
AngularJS utiliza $scope
llama al objeto de controlador.
En AngularJS, $scope es el objeto de aplicación (propietario de todas las variables y funciones de la aplicación).
El controlador en el rango (firstName
y lastName
)crea dos propiedades (variables).
ng-model
Las directivas enlazan los campos de entrada a las propiedades del controlador (firstName y lastName).
Métodos del controlador
El ejemplo anterior muestra un objeto de controlador con dos propiedades: lastName y firstName.
Los controladores pueden tener métodos (como variables de funciones):
Ejemplos de AngularJS
<div ng-app="myApp" ng-controller="personCtrl"> Nombre: <input type="text" ng-model="firstName"><br> Apellido: <input type="text" ng-model="lastName"><br> <br> Nombre completo: {{fullName()}} </div> <script> var app = angular.module('myApp', []); app.controller('personCtrl', function($scope) { $scope.firstName = "Bill"; $scope.lastName = "Gates"; $scope.fullName = function() { return $scope.firstName + " " + $scope.lastName; }; }); </script>
Controladores en archivos externos
En aplicaciones más grandes, es común almacenar controladores en archivos externos.
Simplemente copie el código entre las etiquetas <script> a un archivo llamado personController.js en el archivo externo:
Ejemplos de AngularJS
<div ng-app="myApp" ng-controller="personCtrl"> Nombre: <input type="text" ng-model="firstName"><br> Apellido: <input type="text" ng-model="lastName"><br> <br> Nombre completo: {{fullName()}} </div> <script src="personController.js"></script>
Otro ejemplo
Para el siguiente ejemplo, crearemos un nuevo archivo de controlador:
angular.module('myApp', []).controller('namesCtrl', function($scope) { $scope.names = [ {name:'Jani',country:'Norway'}, {name:'Hege',country:'Sweden'}, {name:'Kai',country:'Denmark'} });
Guarde el archivo como namesController.js:
Luego utilice el archivo de controlador en la aplicación:
Ejemplos de AngularJS
<div ng-app="myApp" ng-controller="namesCtrl"> <ul> <li ng-repeat="x in names"> {{ x.name + ', ' + x.country }} </li> </ul> </div> <script src="namesController.js"></script>
- Página anterior Vínculos de datos de AngularJS
- Página siguiente Scope de AngularJS