我有一個簡單的AngularJS應用程序,我試圖重構使用RequireJS。如何使用AngularJS和RequireJS解決項目的依賴關係?
由於控制器和服務加載異步,我不能在我的index.html
中使用ng-app。
以下是我main.js
require.config({
paths: {
"angular": '../../bower_components/angular/angular',
"angularCookies": '../../bower_components/angular-cookies/angular-cookies'
},
shim: {
angular: {
exports: "angular"
},
angularCookies : {
deps: ["angular"]
}
}
});
require(['angular', './login/js/login'],
function (angular) {
angular.bootstrap(document, ['loginApp']);
}
);
我login.js
就是我定義的角度模塊。 以下是我login.js
'use strict';
define(['angular',
'angularCookies',
'./login.controller'],
function(angular, angularCookies, loginController) {
angular.module('loginApp', [
'ngCookies'])
.config(['$cookiesProvider',
function($cookiesProvider) {
$cookiesProvider.defaults.path = '/';
$cookiesProvider.defaults.domain = 'localhost';
}
])
.run(['$cookies',
'loginService',
function($cookies, loginService) {
}
]).controller(loginController);
});
正如所看到的,它依賴於loginController
和loginController
是依賴於loginService
。
我loginService
定義爲 -
"use strict";
define(['angular',
'angularCookies'],
function (angular, angularCookies) {
var loginService = angular.module('loginApp')
.factory('loginService', [
'$http',
'$cookies',
function ($http, $cookies) {
// My functions and other code here.
}]);
return loginService;
});
有了這個配置,我得到一個錯誤 - Module 'loginApp' 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.
缺少什麼我在這裏? 我需要做什麼配置才能使它正確?
謝謝您的建議。但我有幾個問題,1.我在哪裏配置我的loginApp? 2. login.js發生了什麼? – pratiksanglikar
看看這篇文章:https://www.startersquad.com/blog/angularjs-requirejs/ – Yaser
解決了這個問題。謝謝! :) – pratiksanglikar