AngularJS基于ui-route实现深层路由的方法【路由嵌套】


Posted in Javascript onDecember 14, 2016

本文实例讲述了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="js/angular-ui-router.js"></script>

(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下的路径建议使用绝对路径的形式。

效果如下,当初始默认界面为:

AngularJS基于ui-route实现深层路由的方法【路由嵌套】

点击水果,切换到水果页面:

AngularJS基于ui-route实现深层路由的方法【路由嵌套】

点击蔬菜,切换到蔬菜页面:

AngularJS基于ui-route实现深层路由的方法【路由嵌套】

这里介绍了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'
});

最后我们来看效果:现在点击水果一级切换页面之后显示为:

AngularJS基于ui-route实现深层路由的方法【路由嵌套】

在点击橘子,苹果或者香蕉进行选择,其效果为,即二级切换页面的效果为:

AngularJS基于ui-route实现深层路由的方法【路由嵌套】

4.此外ui-route还可以实现多视图路由,这个功能同一个state下,全页面分为几个细小的页面分别显示不同的值。

希望本文所述对大家AngularJS程序设计有所帮助。

Javascript 相关文章推荐
FCK调用方法..
Dec 21 Javascript
用js实现的检测浏览器和系统的函数
Apr 09 Javascript
jQuery 扩展对input的一些操作方法
Oct 30 Javascript
利用JS进行图片的切换即特效展示图片
Dec 03 Javascript
javascript的BOM汇总
Jul 16 Javascript
学习Bootstrap组件之下拉菜单
Jul 28 Javascript
javascript HTML+CSS实现经典橙色导航菜单
Feb 16 Javascript
浅谈vue项目如何打包扔向服务器
May 08 Javascript
解决cordova+vue 项目打包成APK应用遇到的问题
May 10 Javascript
Node.js+ELK日志规范的实现
May 23 Javascript
django中使用vue.js的要点总结
Jul 07 Javascript
在vue中axios设置timeout超时的操作
Sep 04 Javascript
基于JS实现弹出一个隐藏的div窗口body页面变成灰色并且不可被编辑
Dec 14 #Javascript
Bootstrap实现圆角、圆形头像和响应式图片
Dec 14 #Javascript
BootStrap 下拉菜单点击之后不会出现下拉菜单(下拉菜单不弹出)的解决方案
Dec 14 #Javascript
深入理解jquery中的each用法
Dec 14 #Javascript
Bootstrap基本模板的使用和理解1
Dec 14 #Javascript
Bootstrap栅格系统的使用和理解2
Dec 14 #Javascript
jQuery的extend方法【三种】
Dec 14 #Javascript
You might like
hadoop常见错误以及处理方法详解
2013/06/19 PHP
讲解WordPress开发中一些常用的debug技巧
2015/12/18 PHP
apache集成php7.3.5的详细步骤
2019/06/20 PHP
把input初始值不写value的具体实现方法
2013/07/04 Javascript
jQuery简易图片放大特效示例代码
2014/06/09 Javascript
jQuery标签替换函数replaceWith()的使用例子
2014/08/28 Javascript
jQuery中queue()方法用法实例
2014/12/29 Javascript
jQuery幻灯片带缩略图轮播效果代码分享
2015/08/17 Javascript
jQuery实现分隔条左右拖动功能
2015/11/21 Javascript
node-http-proxy修改响应结果实例代码
2016/06/06 Javascript
AngularJS 路由和模板实例及路由地址简化方法(必看)
2016/06/24 Javascript
JavaScript实现提交模式窗口后刷新父窗口数据的方法
2017/06/16 Javascript
vue2.0 自定义组件的方法(vue组件的封装)
2018/06/05 Javascript
Vue拖拽组件列表实现动态页面配置功能
2019/06/17 Javascript
javascript中的this作用域详解
2019/07/15 Javascript
VSCode 配置uni-app的方法
2020/07/11 Javascript
微信小程序12行js代码自己写个滑块功能(推荐)
2020/07/15 Javascript
Python脚本实现代码行数统计代码分享
2015/03/10 Python
基于Python实现文件大小输出
2016/01/11 Python
python中星号变量的几种特殊用法
2016/09/07 Python
用python实现k近邻算法的示例代码
2018/09/06 Python
Python文件读写保存操作的示例代码
2018/09/14 Python
PyQt5 在label显示的图片中绘制矩形的方法
2019/06/17 Python
python数据分析工具之 matplotlib详解
2020/04/09 Python
Python super()函数使用及多重继承
2020/05/06 Python
浅析python字符串前加r、f、u、l 的区别
2021/01/24 Python
几个判断型的面试题
2012/07/03 面试题
中英文自我评价语句
2013/12/20 职场文书
《落花生》教学反思
2014/02/25 职场文书
施工单位安全责任书
2014/07/24 职场文书
学校端午节活动方案
2014/08/23 职场文书
2015年毕业生个人自荐书
2015/03/24 职场文书
JavaScript嵌入百度地图API的最详细方法
2021/04/16 Javascript
TaiShan 200服务器安装Ubuntu 18.04的图文教程
2022/06/28 Servers
Win11如何默认打开软件界面最大化?Win11默认打开软件界面最大化的方法
2022/07/15 数码科技
HTML中link标签属性的具体用法
2023/05/07 HTML / CSS