AngularJs根據(jù)訪問的頁面動(dòng)態(tài)加載Controller的解決方案
用Ng就是想做單頁面應(yīng)用(simple page application),就是希望站內(nèi)所有的頁面都是用Ng的Route,盡量不用location.href,但是這樣的webapp好處是很多,但是美中不足的是當(dāng)你的webapp隨著時(shí)間的推移,用戶變多,功能變得更豐富,controller也變得越來越多,你不得不把所有的controller當(dāng)作全局模塊進(jìn)行加載,以使得在站內(nèi)任何一個(gè)頁面中按F5刷新后能route到任意一個(gè)其他頁面,而不會(huì)發(fā)生找不到controller的錯(cuò)誤,加載所有的controller使得在手機(jī)端上,頁面的首次打開速度變慢,今天我就和大家分享我是怎么改善這個(gè)缺點(diǎn)的,實(shí)現(xiàn)Controller的模塊化加載
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é)請點(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
<div ng-controller="MyPluginCtrl">
...
</div>
這樣改造就可以實(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是版本號
}
$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')
}
});
到此只要把原來一個(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可以對需要加載的js進(jìn)行判斷,如果之前已經(jīng)加載過了他會(huì)直接返回成功,也就是說只有在第一次進(jìn)入日期選擇界面時(shí)會(huì)去請求jquery.ui.datepicker.js退出去再進(jìn)就不會(huì)去請求啦
- 同步異步動(dòng)態(tài)引入js文件的幾種方法總結(jié)
- javascript 動(dòng)態(tài)修改css樣式方法匯總(四種方法)
- 動(dòng)態(tài)加載JS文件的三種方法
- 使用jQuery動(dòng)態(tài)加載js腳本文件的方法
- JS動(dòng)態(tài)添加option和刪除option(附實(shí)例代碼)
- js給onclick事件賦值,動(dòng)態(tài)傳參數(shù)實(shí)例解說
- js form action動(dòng)態(tài)修改方法
- jquery及js實(shí)現(xiàn)動(dòng)態(tài)加載js文件的方法
- jquery getScript動(dòng)態(tài)加載JS方法改進(jìn)詳解
- JS動(dòng)態(tài)創(chuàng)建元素的兩種方法
- js動(dòng)態(tài)引入的四種方法
相關(guān)文章
AngularJS監(jiān)聽ng-repeat渲染完成的方法
這篇文章主要介紹了AngularJS監(jiān)聽ng-repeat渲染完成的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-03Angular6使用forRoot() 注冊單一實(shí)例服務(wù)問題
這篇文章主要介紹了Angular6使用forRoot() 注冊單一實(shí)例服務(wù)問題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08Angularjs自定義指令實(shí)現(xiàn)三級聯(lián)動(dòng) 選擇地理位置
這篇文章主要介紹了Angularjs自定義指令實(shí)現(xiàn)三級聯(lián)動(dòng),選擇地理位置,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02Angularjs material 實(shí)現(xiàn)搜索框功能
這篇文章主要介紹了Angularjs material 實(shí)現(xiàn)搜索框功能的相關(guān)資料,需要的朋友可以參考下2016-03-03AngularJs ng-route路由詳解及實(shí)例代碼
這篇文章主要介紹了AngularJs ng-route路由,這里整理相關(guān)資料及簡單實(shí)例代碼,有興趣的小伙伴可以參考下2016-09-09Angular2學(xué)習(xí)教程之ng中變更檢測問題詳解
這篇文章主要給大家介紹了Angular2學(xué)習(xí)教程之ng中變更檢測問題的相關(guān)資料,文中介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。2017-05-05Angular使用過濾器uppercase/lowercase實(shí)現(xiàn)字母大小寫轉(zhuǎn)換功能示例
這篇文章主要介紹了Angular使用過濾器uppercase/lowercase實(shí)現(xiàn)字母大小寫轉(zhuǎn)換功能,涉及AngularJS過濾器針對字符串轉(zhuǎn)換的簡單使用技巧,需要的朋友可以參考下2018-03-03