详解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') }) }) } ); } } } ) }])
另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
文章名称:详解angularjs利用ui-route异步加载组件-创新互联
链接地址:http://myzitong.com/article/csgdcs.html