RequireJS + AngularJS Seed 03 _RequireJS

在 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

相关文章
相关标签/搜索