本文实例讲述了AngularJS基于ui-route实现深层路由的方法。分享给大家供大家参考,具体如下:
1.前面我们通过了简单的ng-route实现了简单层次的路由,对于深层次的路由,我们可以通过ui-route来实现。
(1)ng-route的局限性:一个页面无法嵌套多个视图,也就是说一个页面只能有包含一个页面一个控制器的切换。
(2)ui-route的改进:在具有富客户端的单页应用中,要在一个页面中呈现不同的视图,我们可以通过ui-route实现路由的嵌套。
2 . ui-route的使用方法
(1)首先加载angular-ui-route.js
<script src="/UploadFiles/2021-04-02/angular-ui-router.js">(2)设置HTML页面,这里不同于ng-route中的ng-view
<ul> <li><a ui-sref="index">首页</a></li> <li><a ui-sref="fruit">水果</a></li> <li><a ui-sref="vegetable">蔬菜</a></li> </ul>(3)在JS中配置路由
(因为chorme不支持本地文件访问,而FF支持,这里不想搭建本地服务器的,可以用火狐浏览器调试)
配置路由的代码如下:
angular.module('myapp',['ui.router']) .config(function($stateProvider,$urlRouterProvider){ $urlRouterProvider.otherwise('/index'); $stateProvider.state('fruit',{ url:'/fruit', templateUrl:'fruit.html' }) .state('vegetable',{ url:'/vegetable', templateUrl:'vegetable.html' }) .state('index',{ url:'/index', template:'<h2>这是首页</h2>' }); });因为在这里我们将index.html和fruit.html以及vegetable.html放置在
了同一个目录下,template下的路径建议使用绝对路径的形式。效果如下,当初始默认界面为:
点击水果,切换到水果页面:
点击蔬菜,切换到蔬菜页面:
这里介绍了ui-route页面的基础用法,这个用法与ng-route实现的功能大体上是一致的,下面我们来看各个配置属性的基本含义:
I)template/templateUrl
template:字符串方式的模板内容,或者是一个返回html的函数
templateUrl:模板路径或者是返回模板路径的函数
templateProvider:返回HTML内容的函数例如:在我们的例子中所写的
.state('vegetable',{ url:'/vegetable', templateUrl:'vegetable.html' }) .state('index',{ url:'/index', template:'<h2>这是首页</h2>' });II).controller
控制器,返回对应url模板的控制器名称,或者是对应url模板的控制器函数。如果没有对应的模板定义,控制器对象就不会被创建
III).resolve
使用resolve功能,我们可以准备一组用来注入到控制器的依赖对象。在ngRoute中,resolve可以在实际渲染之前解决掉promise,resolve选项提供一个对象,对象中的key就是准备注入到controller中的依赖名称,值则是这个创建对象的工厂。
3.通过ui-route实现深层次的路由嵌套
我们在水果页面加上了新的html:
<ul> <li><a ui-sref="fruit.orange">橘子</a></li> <li><a ui-sref="fruit.apple">苹果</a></li> <li><a ui-sref="fruit.banana">香蕉</a></li> </ul> <div ui-view></div>我们发现现在一级导航栏底下,多了一个二级导航栏(多了一个ui-view)
重新配置JS路由,在第一级路由fruit的基础上进一步进行嵌套,JS代码
如下:$stateProvider.state('fruit',{ url:'/fruit', templateUrl:'fruit.html' }) .state('vegetable',{ url:'/vegetable', templateUrl:'vegetable.html' }) .state('index',{ url:'/index', template:'<h2>这是首页</h2>' }) .state('fruit.orange',{ url:'/orange', templateUrl:'orange.html', }) .state('fruit.apple',{ url:'/apple', templateUrl:'apple.html' }) .state('fruit.banana',{ url:'/banana', templateUrl:'banana.html' });最后我们来看效果:现在点击水果一级切换页面之后显示为:
在点击橘子,苹果或者香蕉进行选择,其效果为,即二级切换页面的效果为:
4.此外ui-route还可以实现多视图路由,这个功能同一个state下,全页面分为几个细小的页面分别显示不同的值。
更多关于AngularJS相关内容感兴趣的读者可查看本站专题:《AngularJS入门与进阶教程》及《AngularJS MVC架构总结》
希望本文所述对大家AngularJS程序设计有所帮助。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]