app.js
代碼如下:
app.config(function($controllerProvider, $compileProvider, $filterProvider, $provide) {
app.register = {
controller: $controllerProvider.register,
directive: $compileProvider.directive,
filter: $filterProvider.register,
factory: $provide.factory,
service: $provide.service
};
});
在route時(shí)阻塞一下去加載需要的js,加載成功后再繼續(xù),不知道$script是什么的同學(xué)請(qǐng)點(diǎn)http://dustindiaz.com/scriptjs
代碼如下:
$routeProvider.when('/:plugin', {
templateUrl: function(rd) {
return 'plugin/' + rd.plugin + '/index.html';
},
resolve: {
load: function($q, $route, $rootScope) {
var deferred = $q.defer();
var dependencies = [
'plugin/' + $route.current.params.plugin + '/controller.js'
];
$script(dependencies, function () {
$rootScope.$apply(function() {
deferred.resolve();
});
});
return deferred.promise;
}
}
});
controller.js
代碼如下:
app.register.controller('MyPluginCtrl', function ($scope) {
...
});
index.html
代碼如下:
...
這樣改造就可以實(shí)現(xiàn)route時(shí)動(dòng)態(tài)去加載這個(gè)route所依賴的js,但是一般我們的webapp中route都有很多,每個(gè)都要寫那么一堆代碼,既難看又難于維護(hù),我們不妨再優(yōu)化一下
app.js
代碼如下:
app.config(function($controllerProvider, $compileProvider, $filterProvider, $provide) {
app.register = {
controller: $controllerProvider.register,
directive: $compileProvider.directive,
filter: $filterProvider.register,
factory: $provide.factory,
service: $provide.service
};
app.asyncjs = function (js) {
return ["$q", "$route", "$rootScope", function ($q, $route, $rootScope) {
var deferred = $q.defer();
var dependencies = js;
if (Array.isArray(dependencies)) {
for (var i = 0; i < dependencies.length; i++) {
dependencies[i] += "?v=" + v;
}
} else {
dependencies += "?v=" + v;//v是版本號(hào)
}
$script(dependencies, function () {
$rootScope.$apply(function () {
deferred.resolve();
});
});
return deferred.promise;
}];
}
});
代碼如下:
$routeProvider.when('/:plugin', {
templateUrl: function(rd) {
return 'plugin/' + rd.plugin + '/index.html';
},
resolve: {
load: app.asyncjs('plugin/controller.js')
}
});
到此只要把原來(lái)一個(gè)controller.js按模塊拆分成多個(gè)js然后為route添加模塊依賴便可提高加載速度,這個(gè)方法不僅僅可以用在controller按需加載,而且可以用在其他js模塊,例如jquery.ui.datepicker.js這樣的日期選擇插件,在需要日期選擇插件的route節(jié)點(diǎn)加上
代碼如下:
$routeProvider.when('/:plugin', {
templateUrl: function(rd) {
return 'plugin/' + rd.plugin + '/index.html';
},
resolve: {
load: app.asyncjs(['plugin/controller.js','plugin/jquery.ui.datepicker.js'])
}
});
便可以了
PS:$script可以對(duì)需要加載的js進(jìn)行判斷,如果之前已經(jīng)加載過(guò)了他會(huì)直接返回成功,也就是說(shuō)只有在第一次進(jìn)入日期選擇界面時(shí)會(huì)去請(qǐng)求jquery.ui.datepicker.js退出去再進(jìn)就不會(huì)去請(qǐng)求啦
聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com