国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

AngularJs根據(jù)訪問(wèn)的頁(yè)面動(dòng)態(tài)加載Controller的解決方案_AngularJS

來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 21:33:56
文檔

AngularJs根據(jù)訪問(wèn)的頁(yè)面動(dòng)態(tài)加載Controller的解決方案_AngularJS

AngularJs根據(jù)訪問(wèn)的頁(yè)面動(dòng)態(tài)加載Controller的解決方案_AngularJS:用Ng就是想做單頁(yè)面應(yīng)用(simple page application),就是希望站內(nèi)所有的頁(yè)面都是用Ng的Route,盡量不用location.href,但是這樣的webapp好處是很多,但是美中不足的是當(dāng)你的webapp隨著時(shí)間的推移,用戶變多,功能變得更豐富,controller也變得越來(lái)越多
推薦度:
導(dǎo)讀AngularJs根據(jù)訪問(wèn)的頁(yè)面動(dòng)態(tài)加載Controller的解決方案_AngularJS:用Ng就是想做單頁(yè)面應(yīng)用(simple page application),就是希望站內(nèi)所有的頁(yè)面都是用Ng的Route,盡量不用location.href,但是這樣的webapp好處是很多,但是美中不足的是當(dāng)你的webapp隨著時(shí)間的推移,用戶變多,功能變得更豐富,controller也變得越來(lái)越多

用Ng就是想做單頁(yè)面應(yīng)用(simple page application),就是希望站內(nèi)所有的頁(yè)面都是用Ng的Route,盡量不用location.href,但是這樣的webapp好處是很多,但是美中不足的是當(dāng)你的webapp隨著時(shí)間的推移,用戶變多,功能變得更豐富,controller也變得越來(lái)越多,你不得不把所有的controller當(dāng)作全局模塊進(jìn)行加載,以使得在站內(nèi)任何一個(gè)頁(yè)面中按F5刷新后能route到任意一個(gè)其他頁(yè)面,而不會(huì)發(fā)生找不到controller的錯(cuò)誤,加載所有的controller使得在手機(jī)端上,頁(yè)面的首次打開速度變慢,今天我就和大家分享我是怎么改善這個(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é)請(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

文檔

AngularJs根據(jù)訪問(wèn)的頁(yè)面動(dòng)態(tài)加載Controller的解決方案_AngularJS

AngularJs根據(jù)訪問(wèn)的頁(yè)面動(dòng)態(tài)加載Controller的解決方案_AngularJS:用Ng就是想做單頁(yè)面應(yīng)用(simple page application),就是希望站內(nèi)所有的頁(yè)面都是用Ng的Route,盡量不用location.href,但是這樣的webapp好處是很多,但是美中不足的是當(dāng)你的webapp隨著時(shí)間的推移,用戶變多,功能變得更豐富,controller也變得越來(lái)越多
推薦度:
標(biāo)簽: 的方法 js controller
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 欧美日韩国产综合视频在线看 | 亚洲欧美视频在线观看 | 国产精品亚洲色图 | 亚洲高清在线观看视频 | 日韩欧美在线观看 | 欧美一级成人影院免费的 | 国产欧美日韩综合精品无毒 | 国产一级理论免费版 | 欧美亚洲综合视频 | 午夜免费啪啪 | 一区二区国产精品 | 麻豆精品久久久 | 91一区二区三区 | 国产成人三级经典中文 | 国产aⅴ精品一区二区三区久久 | 亚洲精品国产第七页在线 | 夜夜操夜夜 | 国产日韩精品欧美一区视频 | 午夜在线免费视频 | 国产精品ⅴ视频免费观看 | 亚洲精品国产成人99久久 | 黄色网站视频免费 | 国产精品久久久久久久久免费 | 亚洲欧美综合另类 | 2020精品极品国产色在线观看 | 全部费免一级毛片不收费 | 国产日韩欧美在线观看不卡 | 欧美v在线 | 国产成人一区 | 国产亚洲一区二区三区不卡 | 国产网站在线免费观看 | 欧美在线中文 | 欧美韩日 | 国产a久久精品一区二区三区 | 国内精品久久久久激情影院 | 国产在线精品一区二区 | 日韩视频免费看 | 欧美日韩在线一区二区三区 | 国产在线欧美日韩一区二区 | 久久一区二区三区精品 | 亚洲一区二区三区中文字幕 |