带有angularjs的一页中的多个模块

时间:2013-03-23 04:19:10

标签: module angularjs

如何在一个页面中以角度使用多个模块?

我阅读了一些文档,他们说我不能使用ngApp指令,应该使用angular.bootstrap

我的HTML代码:

<div id="M1">
  <div ng-controller="Ctrl">
     <h1>Hello {{name}}</h1>
  </div>
</div>
<div id="M2">
  <div ng-controller="Ctrl">
    [{{name}}]
  </div>
</div>

我的角度代码:

var m1 = angular.module('M1', []);

m1.controller('Ctrl', function($scope) {
  $scope.name = 'M1';
});

var module2 = angular.module('M2', []);
module2.controller('Ctrl', function($scope){
$scope.name = 'M2';
})

angular.bootstrap(document.getElementById('M1'), ['M1']);
angular.bootstrap(document.getElementById('M2'), ['M2']);

但它不起作用。

这是一个现场演示:http://plnkr.co/edit/dkyL8eacoC5ZohfwSWz1?p=preview

1 个答案:

答案 0 :(得分:8)

好像引导过早发生了。修改文档准备就绪时发生的两条boostrap行:

angular.element(document).ready(function() { 
    angular.bootstrap(document.getElementById('M1'), ['M1']);
    angular.bootstrap(document.getElementById('M2'), ['M2']);
});

以这种方式修改plnkr时,两个应用程序都开始正常运行。

现场演示:http://plnkr.co/edit/Of0PYWR5ZEGT5BK4sfhI?p=preview