今天下午学习了下如何使用RequireJS去和AngularJS搭配去组织项目。然后这里稍微介绍下整个配置过程。
RequireJS
RequireJS文档请移步:
RequireJS + AngularJS
因为使用RequireJS去加载整个项目JS文件,因此直接将AngularJS文件引入到项目文件当中是不合理的,所有必须使用RequireJS提供的方式去加载AngularJS。
在你的index.html
文件当中,只需要一个script
标签
这个文件首先加载requirejs
,main.js
里面存放的是所有需要被加载进来文件的配置文件。
接下来就需要在main.js文件里面进行配置了,
require.config({ baseUrl: 'd://angular/app', paths: { 'angular': 'components/angular.min', 'uiRouter': 'components/angular-ui-router.min' }, shim: { 'app': { deps: ['angular'] } }});require(['app'], function(){ angular.bootstrap(document, ['myApp']);})
这里使用require.config()这个全局函数,需要向里面传递一个配置对象。
baseUrl: 'd://angular/app' //所有模块的查找根路径。比如上面的`angular`的路径就应该是基于这个根路径的,为d://angular/app/components/angular.min.jspaths: { 'angular': 'components/angular.min'}//在配置js路径的时候,文件不需要带'.js'后缀,因为一个path有可能映射到一个目录下面。路径解析机制会自动映射模块名到path路径时加上'.js'后缀。shim: { 'app': { deps: ['angular'] }}
shim
为那些没有使用define()来声明依赖关系、设置模块的"浏览器全局变量注入"型脚本做依赖和导出配置。
shim
仅仅只是设置了代码的依赖关系,想要实际的加载shim指定的或涉及的模块,仍然需要一个常规的require/define
调用。设置shim本身不会触发代码的加载。请仅使用其他"shim"模块作为
shim
脚本的依赖,或那些没有依赖关系,并且在调用define()之前定义了全局变量(如jQuery或lodash)的AMD库。否则,如果你使用了一个AMD模块作为一个shim配置模块的依赖,在build之后,AMD模块可能在shim托管代码执行之前都不会被执行,这会导致错误。终极的解决方案是将所有shim托管代码都升级为含有可选的AMD define()调用。
require(['app'], function(){ angular.bootstrap(document, ['myApp']);})
加载'app' module,其内容在下面,首先在'app'模块里面有个deps:['angular'],这里已经申明了依赖关系,即'app'加载以前要先加载angular
,所以在回调里面可以直接使用angular.bootstrap(document, ['myApp'])
去手动启动angular
应用。同时要注意,这粒因为是手动启动angular
,因此不需要在html文件里面加'ng-app'指令作为入口文件。angular.bootstrap(document, ['myApp'])
这里已经声明了'ng-app'指令的位置.
app.js:
define(function () { var app = angular.module('myApp', []); app.controller('DemoController', function ($scope) { $scope.hello = 'world'; }); return app;})
app.js里面的内容就是上面require(['app'],function(){.....}) ,首先加载(即运行)'app.js'里面的内容,然后再调用回调。
OK。这样就通过RequireJS来加载AngularJS了。