最近终于不忙了!!有时间沉淀一下之前学到的angular东东!!

angular路由想必大家已经不陌生了!(陌生的去看我之前那篇手把手教你配置angular路由!)
angular路由作为单页面应用,切换页面的时候都是一个页面,所以切换controller和按需加载控件js就成了大问题!!折腾了我半天啊,angular-route内置的办法也没有解决这个问题,最终我是用requireJs解决的这个问题!!上代码!
1.首先引入requireJs,并且在它的下面用闭包写配置 requirejs(['framework']),这句话的意思是首次进入页面,加载framework
<script src="js/lib/require.min.js"></script>
<script>
(function () {
var jsDir = '/js/';
var jsLibDir = '/js/lib/';
var jsComponentDir = '/components/';
var paths = {
angular: jsLibDir + 'angular.min',
angularRoute: jsLibDir + 'angular-route.min',
jquery: jsLibDir + 'jquery.min',
jQueryMD5: jsLibDir + 'jquery.md5',
highcharts: jsLibDir + 'highcharts',
radialProgress: jsLibDir + 'radialProgress',
d3: jsLibDir + 'd3.min',
echarts: jsLibDir + 'echarts',
framework: jsDir + 'framework',
angularUtil: jsDir + 'angular-util',
standardDashboard: jsDir + 'standard-dashboard',
standardConsole: jsDir + 'standard-console',
standardAmountStatistic: jsDir + 'standard-amount-statistic',
standardReport: jsDir + 'standard-report',
standardAdvancedReport: jsDir + 'standard-advanced-report',
standardExpertAnswer: jsDir + 'standard-expert-answer',
standardService: jsDir + 'standard-service',
standardStrategyInform: jsDir + 'standard-strategy-inform',
standardMember: jsDir + 'standard-member',
standardSchedule: jsDir + 'standard-schedule',
standardChannel: jsDir + 'standard-channel',
standardStrategyMerge: jsDir + 'standard-strategy-merge',
standardIntegrate: jsDir + 'standard-integrate',
standardPersonalCenter: jsDir + 'standard-personal-center',
dateTimePicker: jsComponentDir + 'dateTimePicker/date-time-picker',
fullCalendar: jsComponentDir + 'fullCalendar/fullcalendar',
moment: jsComponentDir + 'fullCalendar/moment'
};
requirejs.config({
paths: paths,
shim: {
angular: {
exports : 'angular',
deps: ['jquery']
},
angularRoute: {
deps: ['angular']
},
jQueryMD5: {
deps: ['jquery']
}
},
//urlArgs: "timeStamp=" + (new Date()).getTime()
//urlArgs: 'v=1.47.1&t=20160719'
});
requirejs(['framework']);
}());
</script>
2.framework.js作为首次加载的js,起到至关重要的作用哈!!定义frameworkApp模块作为主模块,另外加载公共服务utilmodel和ngRoute路由,定义一个resolveController方法,回调函数是requireJs,一会儿会讲到!
//引入模块
var frameworkApp = angular.module('FrameworkApp',['ngRoute', 'utilModule']);
//加载对应的controller
var resolveController = function (names, dependancies) {
//console.log(names)
//console.log(dependancies)
return {
loadController: ['$q', '$rootScope', function ($q, $rootScope) {
var defer = $q.defer();
require(names, function () {
defer.resolve();
$rootScope.$apply();
});
return defer.promise;
}]
};
};
3.配置路由,用resolve方法完成回调,注意回调的是一个list,值是步骤一中定义的模块名称
frameworkApp.config(['$routeProvider', '$controllerProvider', '$provide', '$compileProvider', '$filterProvider',
function ($routeProvider, $controllerProvider, $provide, $compileProvider, $filterProvider) {
frameworkApp.register = {
controller: $controllerProvider.register,
factory: $provide.factory,
service: $provide.service,
filter: $filterProvider.register,
directive: $compileProvider.directive
};
$routeProvider
.when('/',{
redirectTo: '/dashboard'
})
.when('/dashboard',{
templateUrl: 'dashboard.html',
controller: 'DashboardCtrl',
resolve: resolveController(['standardDashboard', 'd3','radialProgress','highcharts'])
})
.when('/console',{
templateUrl: 'console.html',
controller: 'ConsoleCtrl',
resolve: resolveController(['standardConsole'])
})
.when('/amountStatistic',{
templateUrl: 'amount-statistic.html',
controller: 'amountStatisticCtrl',
resolve: resolveController(['standardAmountStatistic','highcharts','dateTimePicker'])
})
.when('/report',{
templateUrl: 'report.html',
controller: 'ReportCtrl',
resolve: resolveController(['standardReport','dateTimePicker'])
})
.when('/advancedReport',{
templateUrl: 'advanced-report.html',
controller: 'advancedReportCtrl',
resolve: resolveController(['standardAdvancedReport','highcharts','dateTimePicker'])
})
.when('/expertAnswer',{
templateUrl: 'expert-answer.html',
controller: 'expertAnswerCtrl',
resolve: resolveController(['standardExpertAnswer'])
})
.when('/service',{
templateUrl: 'service.html',
controller: 'ServiceCtrl',
resolve: resolveController(['standardService'])
})
.when('/strategy-inform',{
templateUrl: 'strategy-inform.html',
controller: 'StrategyInformCtrl',
resolve: resolveController(['standardStrategyInform'])
})
.when('/member',{
templateUrl: 'member.html',
controller: 'MemberCtrl',
resolve: resolveController(['standardMember'])
})
.when('/schedule',{
templateUrl: 'schedule.html',
controller: 'ScheduleCtrl',
resolve: resolveController(['standardSchedule'])
})
.when('/channel',{
templateUrl: 'channel.html',
controller: 'ChannelCtrl',
resolve: resolveController(['standardChannel'])
})
.when('/strategy-merge',{
templateUrl: 'strategy-merge.html',
controller: 'StrategyMergeCtrl',
resolve: resolveController(['standardStrategyMerge'])
})
.when('/integrate',{
templateUrl: 'integrate.html',
controller: 'IntegrateCtrl',
resolve: resolveController(['standardIntegrate'])
})
.when('/personalCenter',{
templateUrl: 'personal-center.html',
controller: 'PersonalCenterCtrl',
resolve: resolveController(['standardPersonalCenter'])
})
.otherwise({
redirectTo: '/error'
});
}]);
4.大功告成啦~完成controller切换,和js按需加载!!!啦啦啦!
5.有一点我也没解决,在引入echarts的时候,用这种方法就报错了,换成highcharts就可以了,折腾半天啊也没把echarts引进来,不过到是发现,在require生效之前引入echarts的话,是可以的!求大神讲解啊!!
<!-- start build --> <script src="js/lib/echarts.js"></script> <script src="js/lib/require.min.js"></script>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# angular路由js加载
# requirejs
# 动态加载js
# angularjs
# 路由加载js
# angularJS+requireJS实现controller及directive的按需加载示例
# 探索angularjs+requirejs全面实现按需加载的套路
# JavaScript模块化之使用requireJS按需加载
# 加载
# 回调
# 首次
# 半天
# 按需
# 的是
# 都是
# 我是
# 这个问题
# 这句话
# 错了
# 大神
# 看我
# 大功告成
# 大问题
# 讲到
# 至关重要
# 会儿
# 解决这个问题
# 忙了
相关文章:
如何在IIS中配置站点IP、端口及主机头?
如何用PHP快速搭建CMS系统?
高端企业智能建站程序:SEO优化与响应式模板定制开发
如何获取上海专业网站定制建站电话?
高防服务器租用指南:配置选择与快速部署攻略
专业网站建设制作报价,网页设计制作要考什么证?
制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?
网站制作免费,什么网站能看正片电影?
建站之星好吗?新手能否轻松上手建站?
保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
建站之星如何开启自定义404页面避免用户流失?
如何在局域网内绑定自建网站域名?
相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?
如何在云主机快速搭建网站站点?
整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?
网站制作软件有哪些,制图软件有哪些?
如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法
如何通过商城自助建站源码实现零基础高效建站?
网站制作企业,网站的banner和导航栏是指什么?
高端网站建设与定制开发一站式解决方案 中企动力
建站之星安装后如何自定义网站颜色与字体?
建站之星收费标准详解:套餐费用及年费价格表一览
,sp开头的版面叫什么?
如何在Golang中引入测试模块_Golang测试包导入与使用实践
太平洋网站制作公司,网络用语太平洋是什么意思?
电商网站制作公司有哪些,1688网是什么意思?
Swift中循环语句中的转移语句 break 和 continue
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
香港服务器网站卡顿?如何解决网络延迟与负载问题?
家庭服务器如何搭建个人网站?
如何获取开源自助建站系统免费下载链接?
C++如何使用std::optional?(处理可选值)
建站之星如何保障用户数据免受黑客入侵?
网站网页制作专业公司,怎样制作自己的网页?
如何实现建站之星域名转发设置?
如何配置WinSCP新建站点的密钥验证步骤?
成都网站制作公司哪家好,四川省职工服务网是做什么用?
建站主机无法访问?如何排查域名与服务器问题
金*站制作公司有哪些,金华教育集团官网?
网站图片在线制作软件,怎么在图片上做链接?
制作充值网站的软件,做人力招聘为什么要自己交端口钱?
如何在万网ECS上快速搭建专属网站?
定制建站流程解析:需求评估与SEO优化功能开发指南
建站之星安装提示数据库无法连接如何解决?
如何快速生成可下载的建站源码工具?
建站ABC备案流程中有哪些关键注意事项?
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
如何在企业微信快速生成手机电脑官网?
如何快速搭建高效简练网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。