最近终于不忙了!!有时间沉淀一下之前学到的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按需加载
# 加载
# 回调
# 首次
# 半天
# 按需
# 的是
# 都是
# 我是
# 这个问题
# 这句话
# 错了
# 大神
# 看我
# 大功告成
# 大问题
# 讲到
# 至关重要
# 会儿
# 解决这个问题
# 忙了
相关文章:
建站之星如何开启自定义404页面避免用户流失?
网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?
宝塔建站后网页无法访问如何解决?
建站之星在线客服如何快速接入解答?
昆明网站制作哪家好,昆明公租房申请网上登录入口?
如何在云服务器上快速搭建个人网站?
沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?
C#如何在一个XML文件中查找并替换文本内容
如何在阿里云虚拟服务器快速搭建网站?
如何通过wdcp面板快速创建网站?
如何通过.red域名打造高辨识度品牌网站?
如何登录建站主机?访问步骤全解析
详解jQuery中基本的动画方法
,柠檬视频怎样兑换vip?
活动邀请函制作网站有哪些,活动邀请函文案?
制作网站的基本流程,设计网站的软件是什么?
XML的“混合内容”是什么 怎么用DTD或XSD定义
无锡营销型网站制作公司,无锡网选车牌流程?
C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)
建站之星如何优化SEO以实现高效排名?
兔展官网 在线制作,怎样制作微信请帖?
小型网站制作HTML,*游戏网站怎么搭建?
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
招贴海报怎么做,什么是海报招贴?
我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?
C++中引用和指针有什么区别?(代码说明)
制作企业网站建设方案,怎样建设一个公司网站?
建站之星手机一键生成:多端自适应+小程序开发快速建站指南
建站之星如何修改网站生成路径?
行程制作网站有哪些,第三方机票电子行程单怎么开?
建站之星如何助力网站排名飙升?揭秘高效技巧
已有域名如何快速搭建专属网站?
C#怎么创建控制台应用 C# Console App项目创建方法
建站之星多图banner生成与模板自定义指南
jQuery 常见小例汇总
制作旅游网站html,怎样注册旅游网站?
如何生成腾讯云建站专用兑换码?
如何批量查询域名的建站时间记录?
网站制作免费,什么网站能看正片电影?
制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?
合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?
招商网站制作流程,网站招商广告语?
如何快速搭建虚拟主机网站?新手必看指南
成都品牌网站制作公司,成都营业执照年报网上怎么办理?
开封网站制作公司,网络用语开封是什么意思?
如何在宝塔面板创建新站点?
专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?
建站主机是否属于云主机类型?
非常酷的网站设计制作软件,酷培ai教育官方网站?
微信小程序 五星评分(包括半颗星评分)实例代码
*请认真填写需求信息,我们会在24小时内与您取得联系。