博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
AngularJS 通过 ocLazyLoad 实现动态(懒)加载模块和依赖
阅读量:4580 次
发布时间:2019-06-09

本文共 2546 字,大约阅读时间需要 8 分钟。

  最近在使用AngularJS,发现AngularJS菜鸟教程上的东西太过于基础,很多东西都没有提及,比如今天的一个关于前端的优化问题,懒加载。通过路由实现地址分发的时候,再通过懒加载模式加载你所需的文件,比如是相关的controller,就是js,这样有利于提高首次加载的负担。

  下面就是一个懒加载的实现过程。

  实现的过程主要是引用3个主要的JS文件:

    

            

  

  然后通过 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"           ] }]);        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文件用做测试

main.html

{
{main.value}}

adminUser.html

{
{adminUser.value}}

main.js

/** * mainCtrl * Created by pkcms.cn on 2016/6/24. */(function () { "use strict" app.controller("mainCtrl", mainCtrlFn); function mainCtrlFn() { this.value = "Hello World"; }}())

adminUser.js

/** * adminUserCtrlFn * Created by pkcms.cn on 2016/6/24. */(function () { app.controller('adminUserCtrl',adminUserCtrlFn); function adminUserCtrlFn() { this.value = "welcome to admin user"; }}());

github url :

此文章来自: » 

转载于:https://www.cnblogs.com/Uncle-Maize/p/5915599.html

你可能感兴趣的文章
window-linux 之间ftp文件互传
查看>>
IOS ARC浅析
查看>>
Django 视图层
查看>>
我的Python入门笔记(6)
查看>>
IO流入门-第八章-BufferedWriter
查看>>
CCT之CAMERA TUNNING调试学习总结
查看>>
linux 下安装bugzilla
查看>>
android开发中scrollview添加自定义view的滑动显示问题
查看>>
OO第三单元作业总结
查看>>
vue通过v-for渲染的列表,可以单独操作的其中的列表的两种方法
查看>>
bzoj 3527 [Zjoi2014]力——FFT
查看>>
Codeforces Round #488 Div. 1
查看>>
Java——动态生成POJO类
查看>>
Valid Parentheses -- LeetCode
查看>>
http协议 cookie设置
查看>>
uva3887Slim Span
查看>>
小米开源监控系统的说明文档
查看>>
openssl链接动态库的方法
查看>>
初识Quartz(入门案例)+常用的Cron表达式
查看>>
【loj#6503.】「雅礼集训 2018 Day4」Magic(生成函数+容斥)
查看>>