在 index.html 里面引用 Requirejs。javascript
<!-- lang: js --> <script type="text/javascript" src="bower_components/requirejs/require.js" data-main="scripts/bootstrap.js"> </script>
这里第一部分src固然就是指requirejs的库文件。第二部分data-main是指入口配置。当前我指定的是scripts下面的bootstrap。requirejs默认的是js文件做为存档格式。因此不写bootstrap.js,直接写bootstrap也行。html
而后在bootstrap中对模块进行配置,java
<!-- lang: js --> require.config({ baseURI: '../scripts', // 根目录。好比说下面的 'app' 模块,就会查找 scripts/app.js paths:{ 'angular' : './libs/angular/angular' // 以AMD格式写的js文件,到这里就能够了 }, shim:{ 'angular' : { exports : 'angular' // Angular不是AMD格式,因此必须向外重命名 } } });
下半段bootstrap
<!-- lang: js --> require( [ 'angular', 'app' // 这里会直接找 'scripts/app.js' 模块。 // AMD不是能够定义id吗,可是这里若是在同一个app里面写两个define, // 貌似是按照顺序加载第一个的。不太明白。之后看。 ], // 这里加载的是angular定义的模块。 // 嗯,开始出现了两个模块。RequireJS的模块和AngularJS的模块。麻烦。 function(angular){ angular.bootstrap(document, ['bearnose']); });
而后再看app.js中的定义:app
<!-- lang: js --> define(['angular'], function(angular){ var app = angular.module('bearnose', []); app.controller("ctrlLogin", function($scope){ $scope.name = "Kitty"; }); return app; });
前面的define是AMD的格式,后面的angular.module是AngularJS的格式。因而这两个就链接起来了。 运行一下,和原先那个同样。requirejs