国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

詳解AngularJS通過ocLazyLoad實現動態(懶)加載模塊和依賴

2024-05-06 15:10:31
字體:
來源:轉載
供稿:網友

最近在使用AngularJS,發現AngularJS菜鳥教程上的東西太過于基礎,很多東西都沒有提及,比如今天的一個關于前端的優化問題,懶加載。通過路由實現地址分發的時候,再通過懶加載模式加載你所需的文件,比如是相關的controller,就是js,這樣有利于提高首次加載的負擔。

下面就是一個懶加載的實現過程。

實現的過程主要是引用3個主要的JS文件:

<script src="angular/1.4.8/angular/angular.min.js"></script><script src="angular/ui-router/release/angular-ui-router.min.js"></script><script src="angular/oclazyload/src/ocLazyLoad.min.js"></script> 

然后通過 APP 配置,將依賴的腳本進行注入操作:

var app = angular.module('pkcms', ["ui.router", "oc.lazyLoad"]);  app.config(["$provide", "$compileProvider", "$controllerProvider", "$filterProvider",     function ($provide, $compileProvider, $controllerProvider, $filterProvider) {       app.controller = $controllerProvider.register;       app.directive = $compileProvider.directive;       app.filter = $filterProvider.register;       app.factory = $provide.factory;       app.service = $provide.service;       app.constant = $provide.constant;     }]);    // 按模塊化加載其他的腳本文件      app.constant('Modules_Config', [       {         name: 'treeControl',         serie: true,         files: [           "Scripts/angular-bootstrap/ui-bootstrap-tpls-0.14.3.min.js"         ]<br>}]);      app.config(["$ocLazyLoadProvider","Modules_Config",routeFn]);      function routeFn($ocLazyLoadProvider,Modules_Config){       $ocLazyLoadProvider.config({       debug:false,       events:false,       modules:Modules_Config   });}; 

以上是初始化動態加載的配置過程。

接著是建立路由:

"use strict"app.config(["$stateProvider","$urlRouterProvider",routeFn]);function routeFn($stateProvider,$urlRouterProvider){ $urlRouterProvider.otherwise("/main"); $stateProvider .state("main",{ url:"/main", templateUrl:"views/main.html", controller:"mainCtrl", controllerAs:"main", resolve:{ deps:["$ocLazyLoad",function($ocLazyLoad){ return $ocLazyLoad.load("controllers/main.js"); }] } }) .state("adminUser",{ url:"/adminUser", templateUrl:"views/adminUser.html", controller:"adminUserCtrl", controllerAs:"adminUser", resolve:{ deps:["$ocLazyLoad",function($ocLazyLoad){ return $ocLazyLoad.load("controllers/adminUser.js"); }] } })};

最后是按路由配置的在對應目錄下建2個HTML頁面文件和2個JS文件用做測試

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 无棣县| 常州市| 陵川县| 安泽县| 安丘市| 金平| 富宁县| 定南县| 遂平县| 民乐县| 昔阳县| 友谊县| 年辖:市辖区| 仁布县| 榆树市| 清原| 定结县| 安康市| 乳山市| 新闻| 大宁县| 江孜县| 灵丘县| 建阳市| 阳新县| 左贡县| 门头沟区| 隆德县| 当涂县| 台州市| 高雄县| 婺源县| 晋中市| 西乌| 枝江市| 平凉市| 三河市| 咸宁市| 子长县| 凤冈县| 彭阳县|