Angular ui-roter 和AngularJS 通过 ocLazyLoad 实现动态(懒)加载模块和依赖


Posted in Javascript onNovember 25, 2018

什么是ui-router

ui-router是AngularUI库最有用的组件之一(AngularUI库由AngularJS社区构建)。它是一个第三方路由框架,允许通过状态机制组织接口,而不是简单的URL路由。

 什么是ocLoayLoad

ocLoayLoad是AngularJS的模块按需加载器。按需加载的对象

 

简单说就是哪个页面需要什么资源,在加载哪个页面的时候在加载,而不是把所有的资源放在模板里。

 三个主要文件

<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>

推荐

1:首先下载插件 可以百度搜索,这里我推荐在线测试的 https://www.bootcdn.cn/angular-ui-router/

2:github url :https://github.com/366065186/angularjs-oclazyload

    3:Angularjs https://code.angularjs.org/

html文件(部分代码)简单说明

1:首先页面引入上面三个文件

2:在a标签中写入 ui-sref='链接路径' 标签

2:在页面定义一块区域用于显示链接内容 <ui-view></ui-view>

Angular ui-roter 和AngularJS 通过 ocLazyLoad 实现动态(懒)加载模块和依赖

 js代码:

首先在module中注入

'ui.router', 'oc.lazyLoad'然后在通过config进行路由配置。

(function () {
 var app = angular.module("app", ['ui.router', 'oc.lazyLoad']) 
 
 // 配置路由
 app.config(function ($stateProvider) {
  $stateProvider
  // 个人中心主页
   .state('admin/index', {
    url: '/admin/index',
    templateUrl: "/admin/index",
    // 加载页面需要的js
    resolve: load(['/static/js/transfer/adminlte/index.js'])
   })
   // 分类管理列表
   .state('class/index', {
    url: '/class/index',
    templateUrl: "/class/index",
    resolve: load([
     '/static/js/transfer/adminlte/classification/index.js'
    ])
   })
   // 轮播图列表
   .state('roll', {
    url: '/roll',
    templateUrl: "/roll",
    resolve: load([
     '/static/js/transfer/adminlte/broadcat.js'
    ])
   })
   // 验证码列表
   .state('code', {
    url: '/code',
    templateUrl: "/code",
    resolve: load([
     '/static/js/transfer/adminlte/code.js'
    ])
   })
   // 电影列表
   .state('movie', {
    url: '/movie',
    templateUrl: "/movie",
    resolve: load([
     '/static/js/transfer/adminlte/movie/movie.js'
    ])
   })
   // 电影编辑
   .state('movie/edit', {
    url: '/movie/edit',
    templateUrl: "/movie/edit",
    resolve: load([
     '/static/js/transfer/adminlte/movie/movieedit.js'
    ])
   })
 });

 // 在加载该模块的时候调用$state.go('admin/index');,以激活admin/index状态。
 app.run(function ($state) {
  $state.go('admin/index');
 });
/*
   * 通过$ocLazyLoad加载页面对应的所需的JS数据
   * 通过$q异步加载JS文件数据其中使用的是promise【保护模式】
  */
function load(srcs, callback) {
 return {
  deps: [
   '$ocLazyLoad', '$q',
   function ($ocLazyLoad, $q) {
    var deferred = $q.defer();
    var promise = false;
    srcs = angular.isArray(srcs) ? srcs : srcs.split(/\s+/);
    if (!promise) {
     promise = deferred.promise;
    }
    angular.forEach(srcs,
     function (src) {
      promise = promise.then(function () {
       angular.forEach([],
        function (module) {
         if (module.name === src) {
          src = module.module ? module.name : module.files;
         }
        });
       return $ocLazyLoad.load(src);
      });
     });
    deferred.resolve();
    return callback ? promise.then(function () {
     return callback();
    }) : promise;
   }
  ]
 };
}
})();

AngularJS路由设置对象参数规则:

属性 类型 描述
template string 在ng-view中插入简单的html内容
templateUrl string 在ng-view中插入html模版文件
controller string,function / array 在当前模版上执行的controller函数
controllerAs string 为controller指定别名
redirectTo string,function 重定向的地址
resolve object 指定当前controller所依赖的其他模块

 效果图:

Angular ui-roter 和AngularJS 通过 ocLazyLoad 实现动态(懒)加载模块和依赖

总结

以上所述是小编给大家介绍的Angular ui-roter 和AngularJS 通过 ocLazyLoad 实现动态(懒)加载模块和依赖,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
js实现图片拖动改变顺序附图
May 13 Javascript
JavaScript函数的调用以及参数传递
Oct 21 Javascript
纯JavaScript基于notie.js插件实现消息提示特效
Jan 18 Javascript
js控制文本框禁止输入特殊字符详解
Apr 07 Javascript
Vue.js上下滚动加载组件的实例代码
Jul 17 Javascript
微信小程序多音频播放进度条问题
Aug 28 Javascript
vue v-for 使用问题整理小结
Aug 04 Javascript
40行代码把Vue3的响应式集成进React做状态管理
May 20 Javascript
使用 Github Actions 自动部署 Angular 应用到 Github Pages的方法
Jul 20 Javascript
解决vue-photo-preview 异步图片放大失效的问题
Jul 29 Javascript
解决nuxt页面中mounted、created、watch执行两遍的问题
Nov 05 Javascript
JavaScript点击按钮生成4位随机验证码
Jan 28 Javascript
详解Vue CLI 3.0脚手架如何mock数据
Nov 23 #Javascript
详解js静态检查工具eslint配置文件
Nov 23 #Javascript
详解小程序不同页面之间通讯的解决方案
Nov 23 #Javascript
创建echart多个联动的示例代码
Nov 23 #Javascript
详解Angular模板引用变量及其作用域
Nov 23 #Javascript
vue使用better-scroll实现下拉刷新、上拉加载
Nov 23 #Javascript
详解Vue2.0组件的继承与扩展
Nov 23 #Javascript
You might like
PHP文件锁定写入实例解析
2014/07/14 PHP
PHP实现基于状态的责任链审批模式详解
2019/05/31 PHP
js arguments.callee的应用代码
2009/05/07 Javascript
javascript下string.format函数补充
2010/08/24 Javascript
jquery foreach使用示例
2013/09/12 Javascript
简单选项卡 js和jquery制作方法分享
2014/02/26 Javascript
如何正确使用javascript 来进行我们的程序开发
2014/06/23 Javascript
js实现交通灯效果
2017/01/13 Javascript
Vuex之理解Mutations的用法实例
2017/04/19 Javascript
vue数据双向绑定的注意点
2017/06/23 Javascript
JavaScript实现身份证验证代码实例
2019/08/26 Javascript
highcharts.js数据绑定方式代码实例
2019/11/13 Javascript
基于Vue2实现移动端图片上传、压缩、拖拽排序、拖拽删除功能
2021/01/05 Vue.js
[08:04]TI4西雅图DOTA2前线报道 海涛探访各路人马
2014/07/09 DOTA
numpy.random.seed()的使用实例解析
2018/02/03 Python
Python使用ConfigParser模块操作配置文件的方法
2018/06/29 Python
Python 实现「食行生鲜」签到领积分功能
2018/09/26 Python
使用python根据端口号关闭进程的方法
2018/11/06 Python
Ubuntu18.04中Python2.7与Python3.6环境切换
2019/06/14 Python
pyqt5 lineEdit设置密码隐藏,删除lineEdit已输入的内容等属性方法
2019/06/24 Python
用OpenCV将视频分解成单帧图片,图片合成视频示例
2019/12/10 Python
python super函数使用方法详解
2020/02/14 Python
Python统计文本词汇出现次数的实例代码
2020/02/27 Python
Python持续监听文件变化代码实例
2020/07/22 Python
python的setattr函数实例用法
2020/12/16 Python
HTML5等待加载动画效果
2017/07/27 HTML / CSS
HTML5 通信API 跨域门槛将不再高、数据推送也不再是梦
2013/04/25 HTML / CSS
欧尚俄罗斯网上超市:Auchan俄罗斯
2018/05/03 全球购物
俄罗斯第一家篮球店:StreetBall
2020/07/30 全球购物
remote接口和home接口主要作用
2013/05/15 面试题
2014年心理健康教育工作总结
2014/12/06 职场文书
贷款承诺书
2015/01/20 职场文书
武当山导游词
2015/02/03 职场文书
2015年三万活动总结
2015/03/25 职场文书
上诉状格式
2015/05/23 职场文书
Python机器学习之决策树和随机森林
2021/07/15 Javascript