<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        AngularJs根據訪問的頁面動態加載Controller的解決方案_AngularJS

        來源:懂視網 責編:小采 時間:2020-11-27 21:33:56
        文檔

        AngularJs根據訪問的頁面動態加載Controller的解決方案_AngularJS

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

        用Ng就是想做單頁面應用(simple page application),就是希望站內所有的頁面都是用Ng的Route,盡量不用location.href,但是這樣的webapp好處是很多,但是美中不足的是當你的webapp隨著時間的推移,用戶變多,功能變得更豐富,controller也變得越來越多,你不得不把所有的controller當作全局模塊進行加載,以使得在站內任何一個頁面中按F5刷新后能route到任意一個其他頁面,而不會發生找不到controller的錯誤,加載所有的controller使得在手機端上,頁面的首次打開速度變慢,今天我就和大家分享我是怎么改善這個缺點的,實現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時阻塞一下去加載需要的js,加載成功后再繼續,不知道$script是什么的同學請點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

        代碼如下:

        ...

        這樣改造就可以實現route時動態去加載這個route所依賴的js,但是一般我們的webapp中route都有很多,每個都要寫那么一堆代碼,既難看又難于維護,我們不妨再優化一下

        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')
        }
        });

        到此只要把原來一個controller.js按模塊拆分成多個js然后為route添加模塊依賴便可提高加載速度,這個方法不僅僅可以用在controller按需加載,而且可以用在其他js模塊,例如jquery.ui.datepicker.js這樣的日期選擇插件,在需要日期選擇插件的route節點加上

        代碼如下:
        $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進行判斷,如果之前已經加載過了他會直接返回成功,也就是說只有在第一次進入日期選擇界面時會去請求jquery.ui.datepicker.js退出去再進就不會去請求啦

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        AngularJs根據訪問的頁面動態加載Controller的解決方案_AngularJS

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

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 成人黄色免费网站| **一级毛片免费完整视| 永久免费看mv网站入口| 亚洲国产日韩在线人成下载| 最近免费最新高清中文字幕韩国| 亚洲AV日韩AV永久无码绿巨人| 99在线免费视频| 久久久久久久综合日本亚洲| 成人久久免费网站| 亚洲爆乳无码精品AAA片蜜桃| 操美女视频免费网站| 亚洲AV综合色区无码一二三区| 在线不卡免费视频| 国产成人+综合亚洲+天堂| 免费h成人黄漫画嘿咻破解版| 日韩在线视频免费| 亚洲中文字幕无码一区二区三区| 中文无码日韩欧免费视频| 日本亚洲视频在线 | 欧美三级在线电影免费| 亚洲中文字幕久久精品无码A| 国产自产拍精品视频免费看| 亚洲a在线视频视频| 国内精品免费麻豆网站91麻豆| 亚洲一区二区三区深夜天堂| 国产又黄又爽又猛的免费视频播放 | 无限动漫网在线观看免费| 亚洲人成无码网站| 美女18毛片免费视频| 亚洲色精品88色婷婷七月丁香| 国产va在线观看免费| 亚洲高清中文字幕免费| 亚洲片国产一区一级在线观看| 亚洲一区免费观看| 亚洲日韩AV无码一区二区三区人| 又粗又硬又黄又爽的免费视频| a级成人毛片免费图片| 99久久国产亚洲综合精品| 亚洲中文字幕无码久久2017| 成人免费视频69| 狠狠躁狠狠爱免费视频无码|