zoukankan      html  css  js  c++  java
  • ui-router中使用ocLazyLoad和resolve

    1.AngularJS按需加载

    AngularJS主要应用开发SPA(Single Page Application)项目,所以在小型项目中,services、filters和controllers都在index.html中加载。Google给的AngularJS官方的angular-seed和angular-phonecat都是这样。

    对于复杂一点,大型的项目,如果所有的内容一开始就加载,对首页的性能影响比较大,即使静态javascript文件使用CDN,对性能还是有很大的影响。所有需要引入按需加载机制,而Angular1.x版本中,ocLazyLoad是一个不错的按钮加载解决方案。

    2.ocLazyLoad的功能

    ocLazyLoad: your solution for lazy loading with Angular 1.x
    入门可以参照:ocLazyLoad快速入门,代码也非常简单:

    • 1.引入ocLazyLoad文件,可以使用npmbower来进行安装
    <script src="//ajax.googleapis.com/ajax/libs/angularjs/1.3.0/angular.min.js"></script>
    <script src="libs/angular-ui-router/angular-ui-router.js"></script>
    <script src="libs/ocLazyLoad/ocLazyLoad.js"></script>
    • 2.注入 oc.lazyLoad模块
    var myApp = angular.module("MyApp", ["oc.lazyLoad"]);
    • 3. 在控制器中加载一个指定的模块
    myApp.controller("MyCtrl", function($ocLazyLoad) {
      $ocLazyLoad.load('testModule.js');
    });

    在实际项目中service和controller文件都是通过ocLazyLoad加载,并且是放在resolve中加载。代码示例如下:

    .state('detail',{
                url:"/detail/:bookId",
                templateUrl:"/templates/detail.html",
                controller:"DetailController",
                controllerAs:'ctrl',
                resolve:{
                    load:['$ocLazyLoad',function($ocLazyLoad){
                        return $ocLazyLoad.load([
                            'services/dataService.js'
                            ]);
                    }],
                    currentBook:['$ocLazyLoad','$stateParams','$injector',function($ocLazyLoad,$stateParams,$injector){
                        var bookId=$stateParams.bookId;
                        return $ocLazyLoad.load('services/booksService.js').then(function(){
                            return $injector.get('booksService').getBookById(bookId);;
                        });
    
                    }]
                }
            })

    3.resolve属性

    resolve在state配置参数中,是一个对象(key-value),每一个value都是一个可以依赖注入的函数,并且返回的是一个promise(当然也可以是值,resloved defer)。

    4.resolve中加载service

    resolve中加载services,但是请求都是异步的,返回的顺序不是按照顺序来的。在currentBook中需要调用booksService里面的getBookById()方法。这个时候虽然在load里面已经加载dataService.js,但是在currentBook中是无法使用getBookById()方法,所以在currentBook对象中,所以必须重新加载booksService.js。这个时候就需要$injector中的get()方法。$injector

    5.图书列表和详细页demo

    image

    image

    代码地址:https://github.com/liminjun/ocLazyLoad-resolve-demo

    6.参考网址

    Angular应用如何实现按需加载

    ocLazyLoad

    ui-router中resolve属性

    综合示例

    http://www.cnblogs.com/xing901022/p/4941166.html

  • 相关阅读:
    反转链表
    《Java JDK7 学习笔记》课后练习题1
    《Java JDK7 学习笔记》课后练习题2
    《java JDK7 学习笔记》课后练习题3
    SQL与NoSQL(关系型与非关系型)数据库的区别
    编程中编码的来源及发展
    JDK7学习笔记之基础类型
    《java JDK7学习笔记》之跨平台与路径设置
    《java jdk7学习笔记》之java三大平台
    VS2015安装之后加装SQL SERVER2014的步骤
  • 原文地址:https://www.cnblogs.com/liminjun88/p/5631291.html
Copyright © 2011-2022 走看看