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

发布时间 - 2026-01-10 23:21:47    点击率:

最近在使用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 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例  潮流网站制作头像软件下载,适合母子的网名有哪些?  ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法  C语言设计一个闪闪的圣诞树  laravel怎么配置Redis作为缓存驱动_laravel Redis缓存配置教程  Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解  Laravel如何实现数据库事务?(DB Facade示例)  javascript中对象的定义、使用以及对象和原型链操作小结  Laravel如何使用Blade组件和插槽?(Component代码示例)  魔方云NAT建站如何实现端口转发?  如何在阿里云香港服务器快速搭建网站?  如何用腾讯建站主机快速创建免费网站?  如何彻底卸载建站之星软件?  非常酷的网站设计制作软件,酷培ai教育官方网站?  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  laravel服务容器和依赖注入怎么理解_laravel服务容器与依赖注入解析  Laravel如何使用Passport实现OAuth2?(完整配置步骤)  Java解压缩zip - 解压缩多个文件或文件夹实例  如何选择PHP开源工具快速搭建网站?  使用豆包 AI 辅助进行简单网页 HTML 结构设计  Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门  浅析上传头像示例及其注意事项  如何获取免费开源的自助建站系统源码?  Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程  如何为不同团队 ID 动态生成多个非值班状态按钮  Laravel如何使用Livewire构建动态组件?(入门代码)  js实现点击每个li节点,都弹出其文本值及修改  Laravel用户密码怎么加密_Laravel Hash门面使用教程  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法  如何用虚拟主机快速搭建网站?详细步骤解析  Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程  绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信  html如何与html链接_实现多个HTML页面互相链接【互相】  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  如何快速登录WAP自助建站平台?  JS中对数组元素进行增删改移的方法总结  音乐网站服务器如何优化API响应速度?  三星网站视频制作教程下载,三星w23网页如何全屏?  Laravel如何使用Collections进行数据处理?(实用方法示例)  如何快速生成可下载的建站源码工具?  如何在云主机上快速搭建网站?  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  如何自定义建站之星网站的导航菜单样式?  弹幕视频网站制作教程下载,弹幕视频网站是什么意思?  深入理解Android中的xmlns:tools属性  如何快速查询域名建站关键信息?  中山网站推广排名,中山信息港登录入口?  Laravel如何实现API资源集合?(Resource Collection教程)  香港网站服务器数量如何影响SEO优化效果?  如何快速打造个性化非模板自助建站?