1

当我使用 VS2015 模板创建新控制器时,我得到以下代码:

(function () {
    'use strict';

    angular
        .module('app')
        .controller('controller', controller);

    controller.$inject = ['$scope']; 

    function controller($scope) {
        $scope.title = 'controller';

        activate();

        function activate() { }
    }
})();

问题:

  1. 为什么 VS 模板将代码包装在自调用函数中?

  2. 功能有什么问题activate()?我想在里面写什么代码,为什么我需要一个单独的函数而不是仅仅在控制器内写代码?

  3. controller.$inject = ['$scope'];一个更好的做法,然后将依赖项写入数组(作为控制器函数的参数)。

4

1 回答 1

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()调用的位置开始执行业务逻辑。

于 2017-12-27T10:28:54.110 回答