全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解AngularJS通过ocLazyLoad实现动态(懒)加载模块和依赖

最近在使用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文件用做测试

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# angularjs  # oclazyload  # oclazyload加载顺序  # Angular  # 动态加载  # angularjs ocLazyLoad分步加载js文件实例  # AngularJS中的按需加载ocLazyLoad示例  # JS实现图片延迟加载并淡入淡出效果的简单方法  # Webpack 实现 AngularJS 的延迟加载  # AngularJS中的Directive实现延迟加载  # javascript实现图片延迟加载方法汇总(三种方法)  # js实现延迟加载的方法  # 关于延迟加载JavaScript  # 浅析js预加载/延迟加载  # AngularJS使用ocLazyLoad实现js延迟加载  # 加载  # 菜鸟  # 首次  # 其他的  # 所需  # 很多东西  # 大家多多  # 主要是  # 目录下  # provide  # compileProvider  # filterProvider  # controllerProvider  # config  # module  # pkcms  # oc  # lazyLoad  # app  # Modules_Config 


相关文章: 代刷网站制作软件,别人代刷火车票靠谱吗?  Python文件管理规范_工程实践说明【指导】  如何快速生成可下载的建站源码工具?  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  微网站制作教程,我微信里的网站怎么才能复制到浏览器里?  如何用景安虚拟主机手机版绑定域名建站?  如何用已有域名快速搭建网站?  javascript基本数据类型及类型检测常用方法小结  西安大型网站制作公司,西安招聘网站最好的是哪个?  如何配置WinSCP新建站点的密钥验证步骤?  长沙做网站要多少钱,长沙国安网络怎么样?  高性能网站服务器部署指南:稳定运行与安全配置优化方案  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  如何制作网站标识牌,动态网站如何制作(教程)?  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  淘宝制作网站有哪些,淘宝网官网主页?  建站org新手必看:2024最新搭建流程与模板选择技巧  Java解压缩zip - 解压缩多个文件或文件夹实例  利用JavaScript实现拖拽改变元素大小  ,网站推广常用方法?  网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  如何获取上海专业网站定制建站电话?  小说建站VPS选用指南:性能对比、配置优化与建站方案解析  javascript中的try catch异常捕获机制用法分析  我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?  怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?  如何配置IIS站点权限与局域网访问?  建站168自助建站系统:快速模板定制与SEO优化指南  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  公司网站的制作公司,企业网站制作基本流程有哪些?  黑客如何通过漏洞一步步攻陷网站服务器?  网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?  高性能网站服务器配置指南:安全稳定与高效建站核心方案  如何正确选择百度移动适配建站域名?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  建站之星在线版空间:自助建站+智能模板一键生成方案  如何高效完成独享虚拟主机建站?  建站之星云端配置指南:模板选择与SEO优化一键生成  建站之星如何助力企业快速打造五合一网站?  如何高效配置香港服务器实现快速建站?  平台云上自助建站如何快速打造专业网站?  网站制作多少钱一个,建一个论坛网站大约需要多少钱?  Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递  建站之星IIS配置教程:代码生成技巧与站点搭建指南  整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  七夕网站制作视频,七夕大促活动怎么报名?  如何续费美橙建站之星域名及服务?  如何快速搭建支持数据库操作的智能建站平台? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。