详解angularjs利用ui-route异步加载组件
发布时间 - 2026-01-11 01:13:02 点击率:次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
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
javascript如何操作浏览器历史记录_怎样实现无刷新导航
Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出
javascript日期怎么处理_如何格式化输出
怎么用AI帮你为初创公司进行市场定位分析?
香港服务器网站推广:SEO优化与外贸独立站搭建策略
长沙企业网站制作哪家好,长沙水业集团官方网站?
如何快速查询网址的建站时间与历史轨迹?
Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程
瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口
详解Huffman编码算法之Java实现
如何快速搭建高效WAP手机网站?
如何在Ubuntu系统下快速搭建WordPress个人网站?
如何获取上海专业网站定制建站电话?
php静态变量怎么调试_php静态变量作用域调试技巧【解答】
高防服务器租用如何选择配置与防御等级?
详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南
如何在万网开始建站?分步指南解析
如何确保西部建站助手FTP传输的安全性?
如何正确下载安装西数主机建站助手?
iOS中将个别页面强制横屏其他页面竖屏
Laravel怎么实现验证码功能_Laravel集成验证码库防止机器人注册
Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区
教学论文网站制作软件有哪些,写论文用什么软件
?
宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法
浏览器如何快速切换搜索引擎_在地址栏使用不同搜索引擎【搜索】
油猴 教程,油猴搜脚本为什么会网页无法显示?
Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】
Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制
HTML 中如何正确使用模板变量为元素的 name 属性赋值
JavaScript中如何操作剪贴板_ClipboardAPI怎么用
JS中页面与页面之间超链接跳转中文乱码问题的解决办法
动图在线制作网站有哪些,滑动动图图集怎么做?
DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解
Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例
Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】
深入理解Android中的xmlns:tools属性
如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环
Laravel路由Route怎么设置_Laravel基础路由定义与参数传递规则【详解】
浅谈Javascript中的Label语句
Laravel如何实现API版本控制_Laravel API版本化路由设计策略
如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?
百度浏览器如何管理插件 百度浏览器插件管理方法
Laravel如何处理CORS跨域请求?(配置示例)
Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】
Laravel的Blade指令怎么自定义_创建你自己的Laravel Blade Directives
做企业网站制作流程,企业网站制作基本流程有哪些?
Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权
jquery插件bootstrapValidator表单验证详解
WordPress 子目录安装中正确处理脚本路径的完整指南
Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件

