亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

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

2019-11-20 13:13:42
字體:
來源:轉載
供稿:網友

用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

復制代碼 代碼如下:

<div ng-controller="MyPluginCtrl">
  ...
</div>

這樣改造就可以實現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退出去再進就不會去請求啦

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91夜夜揉人人捏人人添红杏| 欧美激情xxxx性bbbb| 中文字幕一区日韩电影| 亚洲国产精品久久久| 欧美人交a欧美精品| 国产一区二区三区久久精品| 中国人与牲禽动交精品| 中文字幕亚洲一区在线观看| 日本视频久久久| 亚洲小视频在线| 中文字幕亚洲专区| 中文字幕亚洲专区| 亚洲天堂男人的天堂| 宅男66日本亚洲欧美视频| 亚洲国产精彩中文乱码av| 亚洲日本中文字幕免费在线不卡| 国产成人短视频| 国产ts人妖一区二区三区| 欧美性受xxxx白人性爽| 91精品国产高清自在线| 欧美成人精品h版在线观看| 精品国产乱码久久久久酒店| 日韩成人在线网站| 亚洲xxx自由成熟| 国产欧美一区二区三区在线看| 国产欧美日韩综合精品| 992tv在线成人免费观看| 久久久91精品国产一区不卡| 日韩av在线最新| 日韩精品欧美激情| 91精品国产99久久久久久| 国产精品99久久久久久白浆小说| 最新国产成人av网站网址麻豆| 日韩在线免费观看视频| 国产视频精品免费播放| 97成人精品区在线播放| 一本色道久久88亚洲综合88| 成人精品一区二区三区| 中文字幕久精品免费视频| 国产精品va在线| 国产精品视频免费在线| 亚洲自拍偷拍在线| 中文字幕欧美日韩精品| 国产精品免费一区二区三区都可以| 4438全国亚洲精品在线观看视频| 久精品免费视频| 欧美国产亚洲视频| 国产日韩综合一区二区性色av| 91精品国产高清自在线看超| 国产精品99导航| 亚洲人成电影网站色xx| 精品视频久久久| 色综合天天狠天天透天天伊人| 成人天堂噜噜噜| 亚洲色图综合网| 中文字幕在线成人| 91爱爱小视频k| 在线国产精品播放| 日韩av在线电影网| 精品动漫一区二区| 久久久久久久一区二区三区| 精品精品国产国产自在线| 亚洲精品网址在线观看| www.午夜精品| 丝袜亚洲另类欧美重口| 亚洲视频在线播放| 91精品视频在线看| 懂色av中文一区二区三区天美| 成人在线视频网| 欧美肥老妇视频| 91在线免费观看网站| 亚洲自拍另类欧美丝袜| 国产欧美一区二区三区在线| 亚洲天堂av综合网| 精品久久久久久中文字幕大豆网| 日韩hd视频在线观看| 中日韩午夜理伦电影免费| 热99久久精品| 欧美日韩人人澡狠狠躁视频| 国产精品网站大全| 亚洲国产精品一区二区久| 国内精品久久久久久久| 91美女高潮出水| 精品国产网站地址| 国产精品男人的天堂| 国产一区二区日韩精品欧美精品| 91九色精品视频| 日韩激情av在线免费观看| 中文字幕不卡在线视频极品| 中文字幕不卡在线视频极品| 国产欧美一区二区三区在线看| 欧美高清性猛交| 久久久这里只有精品视频| 日韩欧美在线视频免费观看| 亚洲国产美女精品久久久久∴| 久久精品亚洲94久久精品| 国产精品青青在线观看爽香蕉| 国产精品久久网| 国产精品免费看久久久香蕉| 欧美成人免费播放| 国产精品视频一区二区三区四| 欧美在线播放视频| 欧美在线xxx| 日韩中文字幕第一页| 九九热99久久久国产盗摄| 久久婷婷国产麻豆91天堂| 国产精品r级在线| 国产亚洲视频在线观看| 91精品国产综合久久男男| 欧美视频在线免费| 欧美激情视频在线观看| 国产成人a亚洲精品| 欧美精品免费在线| 亚洲电影成人av99爱色| 成人网欧美在线视频| 国产精品美女主播在线观看纯欲| 在线亚洲男人天堂| 亚洲国产精品高清久久久| 亚洲iv一区二区三区| 91黑丝高跟在线| 亚洲最大福利网| 日韩男女性生活视频| 在线国产精品播放| 欧美一级淫片丝袜脚交| 久久免费少妇高潮久久精品99| 亲爱的老师9免费观看全集电视剧| 在线观看91久久久久久| 欧美成人精品三级在线观看| 欧美日韩国内自拍| 亚洲欧美国产精品专区久久| 欧美日韩在线一区| 2018国产精品视频| 国产狼人综合免费视频| 午夜精品在线视频| 日韩在线免费高清视频| 亚洲高清不卡av| 欧美成人免费视频| 中文字幕久久久| 91免费精品视频| 久久99热精品这里久久精品| 久久久天堂国产精品女人| 日韩亚洲欧美中文高清在线| 成人a在线视频| 国产日韩中文字幕| 久久精品国产一区二区电影| 欧美第一淫aaasss性| 欲色天天网综合久久| 日韩免费高清在线观看| 91精品视频在线播放| 欧美日本高清一区| 91精品视频免费| 韩国19禁主播vip福利视频| 欧美日韩第一视频| 7777精品视频| 国内偷自视频区视频综合| 欧美日韩xxxxx| 性色av一区二区咪爱| 国产欧美婷婷中文| 精品国产31久久久久久| 国产亚洲美女久久| 亚洲福利视频网| 国产精品第一页在线| 国产精品色视频| 精品久久久一区二区|