Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/385.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript Angularjs-AngularUI引导_Javascript_Angularjs_Twitter Bootstrap_Anonymous Function - Fatal编程技术网

Javascript Angularjs-AngularUI引导

Javascript Angularjs-AngularUI引导,javascript,angularjs,twitter-bootstrap,anonymous-function,Javascript,Angularjs,Twitter Bootstrap,Anonymous Function,我正在尝试开发一些Angular.js webapp。在那个应用程序中,我想使用angular-ui.bootstrap。所以我试着这么做,下面是我的app.js代码。我的问题是,为什么会出现这样的错误 reservationController不是未定义的函数 如果我使用推荐的 函数{} 在我的app.js文件的开头 (function() { var app = angular.module('app', ['ngGrid', 'ui.bootstrap']); var reser

我正在尝试开发一些Angular.js webapp。在那个应用程序中,我想使用angular-ui.bootstrap。所以我试着这么做,下面是我的app.js代码。我的问题是,为什么会出现这样的错误

reservationController不是未定义的函数

如果我使用推荐的

函数{}

在我的app.js文件的开头

(function() {
  var app = angular.module('app', ['ngGrid', 'ui.bootstrap']);

  var reservationController = function ($scope, $modal, $log) {
    $scope.items = ['item1', 'item2', 'item3'];
    $scope.open = function (size) {
      var modalInstance = $modal.open({
        templateUrl: 'reservationTemplate.html',
        controller: ModalInstanceCtrl,
        size: size,
        resolve: {
          items: function () {
            return $scope.items;
          }
        }
      });
      modalInstance.result.then(function (selectedItem) {
        $log.info('Foo');
      }, function () {
        $log.info('Modal dismissed at: ' + new Date());
      });
    };
  };

// Please note that $modalInstance represents a modal window (instance) dependency.
// It is not the same as the $modal service used above.

var ModalInstanceCtrl = function ($scope, $modalInstance, items) {
  $scope.items = items;
  $scope.selected = {
    item: $scope.items[0]
  };
  $scope.ok = function () {
    $modalInstance.close();
  };

  $scope.cancel = function () {
    $modalInstance.dismiss('cancel');
  };
};

})();

这是planker的url,您使用的是哪个版本的angular?如果使用1.3x Hello。我正在使用AngularJSV1.2.21。我刚刚发现,如果我删除函数{};在我的js文件的开头和结尾,它都能正常工作。否则,如果我将控制器名称保留为不带var关键字,它也会工作。但我不能向自己解释,所以我可以弄清楚,这里发生了什么。这是因为当你省略var关键字时,它会成为全局对象的一部分,angular 1.2也会查看全局对象以获取控制器,这将在1.3中中断。推荐的方法是像您已经做的那样在闭包中编写控制器,并使用.controller语法注册它,这样您就不会污染globals。好的,谢谢您的帮助。我知道这一点听起来很有用。我想问一个关于如何使用angluar-ui.bootstrap组件的问题,对吗?我应该使用.controller语法注册控制器,还是应该像angular ui网站上所说的那样使用它?如果是modal的控制器,我想你应该会很好,因为ui引导通过查看函数引用来处理它,在下一行中,你将提供函数引用作为控制器的构造函数。。。