全网整合营销服务商

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

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

详解angularjs利用ui-route异步加载组件

ui-route相比于angularjs的原生视图路由更好地支持了路由嵌套,状态转移等等。随着视图不断增加,打包的js体积也会越来越大,比如我在应用里面用到了wangeditor里面单独依赖的jquery就300多k。异步加载各个组件就很有必要。在这里我就以ui-route为框架来进行异步加载说明。

首先看一下路由加载文件

angular.module('webtrn-sns').config(['$stateProvider', function ($stateProvider) {
  $stateProvider.state({
      name: 'home.message',
      url: '/message',
      abstract: true,
      templateProvider: ['resources', function (resources) {
        return resources.template
      }],
      controllerProvider: ['resources', (resources)=> {
        return resources.controller
      }],
      onEnter: ['resources', (resources)=>resources.css.use()],
      onExit: ['resources', (resources)=>resources.css.unuse()],
      resolve: {
        resources: ()=> {
          return new Promise(
            resolve => {
              require([], () => {
                resolve({
                  css: require('./css/message_box.css'),
                  template: require('./html/message_box.html'),
                  controller: require('./js/message_box.js')
                })
              })
            }
          );
        }
      }
    }
  ).state({
      name: 'home.message.add_message',
      url: '/add_message?isReply&toUid&title',
      params: {isReply: null, toUid: null, title: null},
      templateProvider: ['resources', function (resources) {
        return resources.template
      }],
      controllerProvider: ['resources', (resources)=> {
        return resources.controller
      }],
      onEnter: ['resources', (resources)=>resources.css.use()],
      onExit: ['resources', (resources)=>resources.css.unuse()],
      resolve: {
        resources: ()=> {
          return new Promise(
            resolve => {
              require(['./js/message.js'], () => {
                resolve({
                  css: require('./css/add_message.css'),
                  template: require('./html/add_message.html'),
                  controller: require('./js/add_message.js')
                })
              })
            }
          );
        }
      }
    }
  )
}])

这个是路由状态的一个声明文件,name,url,param字段的方式不变,关键是看resolve这个部分。根据ui-route的resolve文档,resolve是为了给state或者controller进行自定义注入对象的。

下面是举出文档中关于resolve的例子:

$stateProvider.state('myState', {
   resolve:{
     // Example using function with simple return value.
     // Since it's not a promise, it resolves immediately.
     simpleObj: function(){
      return {value: 'simple!'};
     },
     // Example using function with returned promise.
     // This is the typical use case of resolve.
     // You need to inject any services that you are
     // using, e.g. $http in this example
     promiseObj: function($http){
      // $http returns a promise for the url data
      return $http({method: 'GET', url: '/someUrl'});
     },
     // Another promise example. If you need to do some 
     // processing of the result, use .then, and your 
     // promise is chained in for free. This is another
     // typical use case of resolve.
     promiseObj2: function($http){
      return $http({method: 'GET', url: '/someUrl'})
        .then (function (data) {
          return doSomeStuffFirst(data);
        });
     },    
     // Example using a service by name as string.
     // This would look for a 'translations' service
     // within the module and return it.
     // Note: The service could return a promise and
     // it would work just like the example above
     translations: "translations",
     // Example showing injection of service into
     // resolve function. Service then returns a
     // promise. Tip: Inject $stateParams to get
     // access to url parameters.
     translations2: function(translations, $stateParams){
       // Assume that getLang is a service method
       // that uses $http to fetch some translations.
       // Also assume our url was "/:lang/home".
       return translations.getLang($stateParams.lang);
     },
     // Example showing returning of custom made promise
     greeting: function($q, $timeout){
       var deferred = $q.defer();
       $timeout(function() {
         deferred.resolve('Hello!');
       }, 1000);
       return deferred.promise;
     }
   },
   // The controller waits for every one of the above items to be
   // completely resolved before instantiation. For example, the
   // controller will not instantiate until promiseObj's promise has 
   // been resolved. Then those objects are injected into the controller
   // and available for use. 
   controller: function($scope, simpleObj, promiseObj, promiseObj2, translations, translations2, greeting){
     $scope.simple = simpleObj.value;
     // You can be sure that promiseObj is ready to use!
     $scope.items = promiseObj.data.items;
     $scope.items = promiseObj2.items;
     $scope.title = translations.getLang("english").title;
     $scope.title = translations2.title;
     $scope.greeting = greeting;
   }
  })

我们可以看到resolve的对象是支持Promise的。

再回到我们之前的代码templateProvider和controllerProvider我们注入了resources的模板对象和controller对象,onEnter和onExit注入了css模块。

如果controller中依赖了服务怎么办的?

resolve: {
  resources: ()=> {
    return new Promise(
      resolve => {
        require(['./js/message.js'], () => {
          resolve({
            css: require('./css/add_message.css'),
            template: require('./html/add_message.html'),
            controller: require('./js/add_message.js')
          })
        })
      }
    );
  }
}

可以在require里面将服务注入,如代码中的message.js。而为了将服务进行异步加载我们不能用普通的.factory或者.service。而需要调用$provide.factory或者$provide.service

如果采用webpack进行编译打包的话就需要webpack.optimize.CommonsChunkPlugin的支持,这样可以对js进行拆分打包,达到异步加载js的目的。

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


# angularjs  # 异步加载组件  # angularjs2  # 异步加载  # JavaScript文件的同步和异步加载的实现代码  # JS异步加载的三种实现方式  # jquery使用EasyUI Tree异步加载JSON数据(生成树)  # 如何使用headjs来管理和异步加载js  # 异步加载JS、CSS代码(推荐)  # 浅析JS异步加载进度条  # 点评js异步加载的4种方式  # JavaScript异步加载浅析  # 如何调试异步加载页面里包含的js文件  # javascript写的异步加载js文件函数(支持数组传参)  # JavaScript异步加载问题总结  # 加载  # 文档  # 我在  # 也会  # 在这  # 很有  # 可以看到  # 自定义  # 看一下  # 不能用  # 以对  # 就以  # 里我  # 大家多多  # 再回  # 是为了  # 更好地  # Promise  # resolve  # unuse 


相关文章: 制作证书网站有哪些,全国城建培训中心证书查询官网?  如何通过商城自助建站源码实现零基础高效建站?  一键制作网站软件下载安装,一键自动采集网页文档制作步骤?  建站之星在线版空间:自助建站+智能模板一键生成方案  如何做静态网页,sublimetext3.0制作静态网页?  定制建站平台哪家好?企业官网搭建与快速建站方案推荐  制作公司内部网站有哪些,内网如何建网站?  建站主机助手选型指南:2025年热门推荐与高效部署技巧  北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?  高端网站建设与定制开发一站式解决方案 中企动力  5种Android数据存储方式汇总  建站org新手必看:2024最新搭建流程与模板选择技巧  佛山企业网站制作公司有哪些,沟通100网上服务官网?  大型企业网站制作流程,做网站需要注册公司吗?  ,有什么在线背英语单词效率比较高的网站?  网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?  c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗  宝塔新建站点为何无法访问?如何排查?  制作销售网站教学视频,销售网站有哪些?  ppt制作免费网站有哪些,ppt模板免费下载网站?  小建面朝正北,A点实际方位是否存在偏差?  如何通过建站之星自助学习解决操作问题?  建站主机是什么?如何选择适合的建站主机?  公司网站设计制作厂家,怎么创建自己的一个网站?  建站之星展会模板:智能建站与自助搭建高效解决方案  如何快速搭建支持数据库操作的智能建站平台?  ,巨量百应是干嘛的?  如何通过虚拟主机空间快速建站?  常州企业建站如何选择最佳模板?  个人网站制作流程图片大全,个人网站如何注销?  建站之星云端配置指南:模板选择与SEO优化一键生成  临沂网站制作企业,临沂第三中学官方网站?  如何快速搭建高效简练网站?  招贴海报怎么做,什么是海报招贴?  制作网站的软件免费下载,免费制作app哪个平台好?  营销式网站制作方案,销售哪个网站招聘效果最好?  大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?  如何在IIS管理器中快速创建并配置网站?  如何选择香港主机高效搭建外贸独立站?  网站制作免费,什么网站能看正片电影?  如何选择服务器才能高效搭建专属网站?  php条件判断怎么写_ifelse和switchcase的使用区别【对比】  相册网站制作软件,图片上的网址怎么复制?  建站之星后台密码遗忘或太弱?如何重置与强化?  简单实现Android文件上传  如何用y主机助手快速搭建网站?  如何在香港免费服务器上快速搭建网站?  小说建站VPS选用指南:性能对比、配置优化与建站方案解析  如何实现建站之星域名转发设置?  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo? 

您的项目需求

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