簡體   English   中英

RequireJS r.js優化后的AngularJs $ injector:modulerr

[英]AngularJs $injector:modulerr after RequireJS r.js optimization

AngularJS-RequireJS應用程序即時消息構建引發了未捕獲的錯誤:[$ injector:modulerr]由於以下原因而無法實例化模塊myApp失敗:錯誤:[$ injector:unpr]未知的提供程序: r.js優化后出現e錯誤。 這個問題以前不存在。 我在此鏈接上遵循了類似的問題,並將mainConfigFile添加到了生成文件中,但問題仍然存在。 這是各個文件的代碼

build.js

({
    mainConfigFile:'js/main.js',
    appDir: "./",
    baseUrl: "js",
    dir: "/home/karthic/optimized-test",
    modules: [
        {
            name: "main"
        }
    ]
})

main.js

require.config({
    baseUrl: './js',
    paths: {
        angular: 'libs/angular-1.2.9',
        angularRoute: 'libs/angular-route-1.2.9'
    },
    shim: {
        'angularRoute': {
            deps: ['angular'],
            exports: 'angularRoute'
        },
        'angular': {
            exports: 'angular'
        }
    }

});

require(['angular', 'controller', 'ang_when_routes', 'angularRoute'], function(angular, controller, angWhenRoutes, angularRoute) {
    'use strict';

    var app = angular.module('myApp', ['ngRoute']);
    angular.element(document).ready(function() {
        angular.bootstrap(document, ['myApp']);
    });

    angWhenRoutes.initRoutes(app);
    controller.controllerInit(app);

});

controller.js

define(function() {
     function controllerInit(app) {
         console.log('inside func cont');
         app.controller('mapApp', function($scope, $http, $location) {
             console.log('inside mapp,testing r.js optimizer');
         });
     }
     return {
         controllerInit: controllerInit
     }
 });

ang_when_routes.js

define(function() {
    function initRoutes(app) {
        app.config(
            function($routeProvider, $httpProvider) {
                $httpProvider.defaults.withCredentials = true;
                $routeProvider.
                when('/', {
                    templateUrl: 'index_content.html',
                    controller: 'mapApp'
                })

            });
    }
    return {
        initRoutes: initRoutes
    }
});

的index.html

<!DOCTYPE html>
<html>
    <head>
        <title>Optimizer error</title>
        <script data-main="js/main.js" src="js/libs/require.js"></script>
</head>
<body>
    <div ng-view>

    </div>
</body>

</html>

index_content.html

<p>Testing the r optimizer</p>

如果錯誤可以解決,那對我真的很有幫助

這是@radimKohler在第一條評論中建議的答案。 為了避免在縮小過程中angularJS出現問題,必須按照Angular文檔中的說明使用內聯數組注釋 這是更改后的修改后的代碼

controller.js

define( function () {
     function controllerInit(app) {
         console.log('inside func cont');
         app.controller('mapApp',['$scope','$http','$location', function ($scope, $http, $location) {
             console.log('inside mapp,testing r.js optimizer');

         }]);

     }
     return {
         controllerInit: controllerInit
     }

 });

ang_when_routes.js

define(function(){
    function initRoutes(app){
        app.config(['$routeProvider','$httpProvider',
            function($routeProvider,$httpProvider){
                $httpProvider.defaults.withCredentials = true;
                $routeProvider.
                    when('/',{
                        templateUrl:'index_content.html',
                        controller:'mapApp'
                    })

            }]);    

    }
    return {
        initRoutes:initRoutes
    }
});

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM