时间:2021-05-25
最近在使用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 配置,将依赖的脚本进行注入操作:
以上是初始化动态加载的配置过程。
接着是建立路由:
"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
<div> {{main.value}}</div>adminUser.html<div> {{adminUser.value}}</div>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"; }}());demo下载:angularjs-oclazyload_jb51.rar
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
今天在项目中遇到一个很奇怪的问题,使用oclazyload懒加载angular的模块,刷新页面后,单击回退按钮无法返回上一个页面.估计是使用懒加载机制销毁了an
本文实例讲述了AngularJS动态加载模块和依赖的方法。分享给大家供大家参考,具体如下:前言由于AngularJS是单页面应用框架,在正常的情况下,会在访问页
之前分享了一篇用ocLazyLoad实现按需加载angularjs文件的博客.本来当时想会使用一种方法就行了.可最近刚好有时间,在网上查找了一下requirej
Swift开发之懒加载的实例详解///Adisplaylinkthatkeepscallingthe`updateFrame`methodoneveryscre
本文实例讲述了Python实现动态加载模块、类、函数的方法。分享给大家供大家参考,具体如下:动态加载模块:方式1:系统函数__import__()方式2:imp