最近终于不忙了!!有时间沉淀一下之前学到的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按需加载
# 加载
# 回调
# 首次
# 半天
# 按需
# 的是
# 都是
# 我是
# 这个问题
# 这句话
# 错了
# 大神
# 看我
# 大功告成
# 大问题
# 讲到
# 至关重要
# 会儿
# 解决这个问题
# 忙了
相关文章:
北京网站制作的公司有哪些,北京白云观官方网站?
Android自定义控件实现温度旋转按钮效果
制作国外网站的软件,国外有哪些比较优质的网站推荐?
西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?
上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?
如何选择服务器才能高效搭建专属网站?
黑客入侵网站服务器的常见手法有哪些?
h5在线制作网站电脑版下载,h5网页制作软件?
如何快速生成高效建站系统源代码?
专业商城网站制作公司有哪些,pi商城官网是哪个?
营销式网站制作方案,销售哪个网站招聘效果最好?
建站之星如何一键生成手机站?
广州商城建站系统开发成本与周期如何控制?
想学网站制作怎么学,建立一个网站要花费多少?
高防服务器:AI智能防御DDoS攻击与数据安全保障
Swift开发中switch语句值绑定模式
建站OpenVZ教程与优化策略:配置指南与性能提升
如何选择最佳自助建站系统?快速指南解析优劣
外贸公司网站制作,外贸网站建设一般有哪些步骤?
如何通过建站之星自助学习解决操作问题?
c# 服务器GC和工作站GC的区别和设置
,制作一个手机app网站要多少钱?
网站制作模板下载什么软件,ppt模板免费下载网站?
如何快速上传自定义模板至建站之星?
建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略
,在苏州找工作,上哪个网站比较好?
免费公司网站制作软件,如何申请免费主页空间做自己的网站?
内部网站制作流程,如何建立公司内部网站?
网站制作服务平台,有什么网站可以发布本地服务信息?
建站主机核心功能解析:服务器选择与网站搭建流程指南
建站之星如何防范黑客攻击与数据泄露?
定制建站流程步骤详解:一站式方案设计与开发指南
建站VPS选购需注意哪些关键参数?
如何快速查询域名建站关键信息?
高端云建站费用究竟需要多少预算?
c# 在高并发下使用反射发射(Reflection.Emit)的性能
制作网页的网站有哪些,电脑上怎么做网页?
如何在新浪SAE免费搭建个人博客?
网站制作的方法有哪些,如何将自己制作的网站发布到网上?
如何选择PHP开源工具快速搭建网站?
建站之星如何助力企业快速打造五合一网站?
建站之星如何开启自定义404页面避免用户流失?
如何确保西部建站助手FTP传输的安全性?
新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?
建站之星体验版:智能建站系统+响应式设计,多端适配快速建站
c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】
建站之星各版本价格是多少?
如何通过宝塔面板实现本地网站访问?
如何快速辨别茅台真假?关键步骤解析
代刷网站制作软件,别人代刷火车票靠谱吗?
*请认真填写需求信息,我们会在24小时内与您取得联系。