我是AngularJS路由的新手,所以這可能聽起來像一個noob問題。無法模塊化AngularJS應用程序
我正在一個AngularJS應用程序中有很多控制器。爲了讓我的控制器保持獨立的JS文件,我決定爲每個控制器創建單獨的模塊。
這是我在主模塊angularmodule.js文件。
var app = angular.module('adminpanel', ['ngRoute', 'CustomersModule', 'ngFileUpload', 'wysiwyg.module', 'ui.bootstrap']).config(function ($routeProvider) {
$routeProvider.
when('/customers', {controller: CustomersCtrl, templateUrl: '/app/webroot/jakiamun/easybooks_admin/views/customers.html'}).
otherwise({redirectTo: '/dashboard'});
;
});
這是customers.js第二模塊文件
angular.module('CustomersModule',[])
.config(function ($routeProvider) {
$routeProvider.
when('/customers', {controller: CustomersCtrl, templateUrl: '/app/webroot/jakiamun/easybooks_admin/views/customers.html'}).
otherwise({redirectTo: '/dashboard'});
;
})
.controller("CustomersCtrl" ,function($scope, $rootScope, $http) {
});
在我HTML頁面,我包括這樣
<script src="<?php echo base_url(); ?>/assets/js/angular.min.js"></script>
<script src="<?php echo base_url(); ?>/assets/js/angular-route.min.js"></script>
<script src="<?php echo base_url(); ?>/assets/js/ng-file-upload-shim.min.js"></script> <!-- for no html5 browsers support -->
<script src="<?php echo base_url(); ?>/assets/js/ng-file-upload.min.js"></script>
<script src="<?php echo base_url(); ?>/assets/js/bootstrap-colorpicker-module.min.js"></script>
<script src="<?php echo base_url(); ?>/assets/js/angular-wysiwyg.min.js"></script>
<script src="<?php echo base_url(); ?>/assets/js/ui-bootstrap-tpls-1.1.2.min.js"></script>
<script src="<?php echo base_url(); ?>/assets/js/controllers/customers.js"></script>
<script src="<?php echo base_url(); ?>/assets/js/angularmodule.js"></script>
劇本我寫ng-app='adminpanel'
在身上我的html代碼的標籤。
當我運行我的應用程序時,我得到$injector:modulerr
。
完整的錯誤報告
Failed to instantiate module adminpanel due to:
ReferenceError: CustomersCtrl is not defined
at http://localhost:8088/app/webroot/jakiamun/easybooks_admin//assets/js/angularmodule.js:9:53
at Object.e [as invoke] (http://localhost:8088/app/webroot/jakiamun/easybooks_admin//assets/js/angular.min.js:40:477)
at d (http://localhost:8088/app/webroot/jakiamun/easybooks_admin//assets/js/angular.min.js:39:148)
at http://localhost:8088/app/webroot/jakiamun/easybooks_admin//assets/js/angular.min.js:39:272
at n (http://localhost:8088/app/webroot/jakiamun/easybooks_admin//assets/js/angular.min.js:7:344)
at g (http://localhost:8088/app/webroot/jakiamun/easybooks_admin//assets/js/angular.min.js:39:49)
at fb (http://localhost:8088/app/webroot/jakiamun/easybooks_admin//assets/js/angular.min.js:42:360)
at c (http://localhost:8088/app/webroot/jakiamun/easybooks_admin//assets/js/angular.min.js:19:421)
at zc (http://localhost:8088/app/webroot/jakiamun/easybooks_admin//assets/js/angular.min.js:20:225)
at be (http://localhost:8088/app/webroot/jakiamun/easybooks_admin//assets/js/angular.min.js:19:41
請提供完整的錯誤網址。 – strelok2010
你的'CustomersModule'聲明瞭使用'$ routeProvider'的路由,除了'ngRoute'模塊沒有被注入到這個模塊。 – SuperVeetz
當我將$ routeProvider注入到CustomersModule @SuperVeetz – Shuaib