【发布时间】:2014-02-20 17:58:29
【问题描述】:
我是 AngularJS 的新手,正在创建一个将使用 Grunt 构建的应用程序。
当我构建和运行我的应用程序时,我注意到一些与依赖加载顺序相关的问题:
Uncaught Error: [$injector:nomod] Module 'mycompany.admin.forms' is not available! You either misspelled the module name or forgot to load it. If registering a module ensure that you specify the dependencies as the second argument.
http://errors.angularjs.org/1.2.13/$injector/nomod?p0=mycompany.admin.forms
在构建的应用文件中,模块在声明之前就被使用了:
angular.module('mycompany.admin.forms').controller('editController', ['$scope', function($scope) {
// ...
}]);
angular.module('mycompany.admin.forms', [])
.config(['$routeProvider', function($routeProvider) {
// ...
}]);
这是我项目的 gruntfile.js 中相关的 sn-ps:
grunt.initConfig({
distdir: 'build',
pkg: grunt.file.readJSON('package.json'),
src: {
js: ['src/**/*.js'],
},
concat: {
dist: {
src: ['<%= src.js %>', '<%= src.jsTpl %>'],
dest: '<%= distdir %>/admin/app.js'
}
}
...
});
我知道我可以通过将给定模块的所有源代码放入一个文件来解决这个问题;但是,我想尝试将每个事物(每个控制器、每个服务等)保存在自己的文件中。
如何解决这个依赖加载顺序问题?
【问题讨论】:
标签: javascript angularjs build gruntjs dependency-management