当我使用VS2015模板创建一个新控制器时,我得到了这段代码:
(function () {
'use strict';
angular
.module('app')
.controller('controller', controller);
controller.$inject = ['$scope'];
function controller($scope) {
$scope.title = 'controller';
activate();
function activate() { }
}
})();
问题:
为什么VS模板将代码包装在自调用函数中?
activate()
功能的含义是什么?我想在里面写什么代码,为什么我需要一个单独的函数而不是只是在控制器中编写代码?
将controller.$inject = ['$scope'];
视为一种更好的做法,然后在数组中编写依赖项(作为控制器函数的参数)。
答案 0 :(得分:3)
为什么VS模板将代码包装在自调用函数中?
因为它可以防止破坏全局命名空间。在这种情况下,controller
将在没有IIFE的情况下成为全局命名空间的成员。
activate()
功能的用途是什么?
它有助于分别分离控制器变量和代码的声明和执行。在调用activate
函数之前,我们通常使用this.
语法将所有依赖项声明为控制器成员。
您将在activate
函数中编写执行代码。
controller.$inject = ['$scope'];
是否被视为更好的做法?
其实是的!它可以帮助您将控制器定义与它的角度对应物分开。它可以帮助您避免在angular.module( ... ).controller
块中编写整个控制器代码,以提高代码的可读性。
修改1 :
如果没有IIFE,名为controller
的函数将成为全局命名空间的成员,并且可以在整个页面中访问。它还有可能被后续代码覆盖。不要将AngularJS与此混合,因为这是JavaScript所做的事情。
activate
功能只是一个用于区分问题的图层。您可以完全在函数controller
中编写代码。但是以这种方式,分离哪个代码控制器正在执行以及哪些代码将变量绑定到控制器变得更加困难。举个例子:
function controller($scope) {
var vm = this;
vm.data = [];
$scope.title = 'controller';
activate();
///
function activate() {
getData()
.then(data => {
// do something with data
});
// ...
}
function getData() {
...
}
}
通过阅读上面的代码,人们可以很容易地了解控制器中在线下使用的变量,而无需专门进入控制器的深度。通过遵循此约定,我们将始终知道控制器将在调用activate()
的位置开始执行业务逻辑。