angularjs ui-router中路由的二级嵌套


Posted in Javascript onMarch 10, 2017

关于ui-router中嵌套路由中的问题

1.首先我们的页面层次为

angularjs ui-router中路由的二级嵌套 

其中Main.html是我们的主页,我们要在main.html中对路由进行统一的管理。

main.html页面中有一个ui-view在这里将填充PageTab.html,同时被填充的PageTab.html中也有一个ui-view

这样就实现了嵌套路由。

最终效果:

angularjs ui-router中路由的二级嵌套 

当我们点击Page-1时出现的是Page1中的内容,同理点击Page-2。

下面是实际的代码:

Main.html

<!DOCTYPE html>
<html ng-app="myApp">
<head>
<meta charset="UTF-8">
<title></title>
<script src="js/angular.min.js"></script>
<script src="js/angular-ui-router.js"></script>
<script>  
</script>
</head>
<body>
<h3>Main page</h3>
  <div>
    <div ui-view></div>
  </div>
<script>
  angular.module("myApp",["ui.router"])
  .config(function($stateProvider){
    $stateProvider
    .state("PageTab",{
      url:"",
      templateUrl:"PageTab.html"
    })
    .state("PageTab.Page1",{
      url:"/Page1",
      templateUrl:"Page1.html"
    })
    .state("PageTab.Page2",{
      url:"/Page2",
      templateUrl:"Page2.html"
    })
  })
</script>
</body>
</html>

PageTab.html

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<h2>PageTab</h2>
  <div>
     <span style="width:100px" ui-sref=".Page1"><a href="">Page-1</a></span>
     <span style="width:100px" ui-sref=".Page2"><a href="">Page-2</a></span>
  </div>
  <div ui-view=""></div>
</body>
</html>

Page1.html

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Page1</title>
</head>
<body>
  <h2>Page1</h2>
</body>
</html>

Page2.html

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Page2</title>
</head>
<body>
  <h2>Page2</h2>
</body>
</html>

以上是全部的页面代码,Main.html中js库需要手动导入。

下面我们重点看Main.html中对路由统一管理的部分也就是这段js代码

<script>
  angular.module("myApp",["ui.router"])
  .config(function($stateProvider){
    $stateProvider
    .state("PageTab",{
      url:"",
      templateUrl:"PageTab.html"
    })
    .state("PageTab.Page1",{
      url:"/Page1",
      templateUrl:"Page1.html"
    })
    .state("PageTab.Page2",{
      url:"/Page2",
      templateUrl:"Page2.html"
    })
  })
</script>

一共三个状态:

第一个状态

.state("PageTab",{
      url:"",
      templateUrl:"PageTab.html"
    })

在第一个中我们定义了初始状态名为PageTab,url状态为空,这时候在母版中将会在ui-view中填充PageTab.html这个页面。

第二个状态

.state("PageTab.Page1",{
      url:"/Page1",
      templateUrl:"Page1.html"
    })

我们把这个状态名字命名为PageTab.Page1 这时候的路由将会交给PageTab来处理,即在PageTab.html页面中的ui-view中填充Page1.html中的内容。同理如果state命名为PageTab.Page2 那么处理它的就会是PageTab.html这个页面。

希望本文所述对你有所帮助,angularjs ui-router中路由的二级嵌套就给大家介绍到这里了。希望大家继续关注我们的网站!想要学习angularjs可以继续关注本站。

Javascript 相关文章推荐
ASP.NET中使用后端代码注册脚本 生成JQUERY-EASYUI的界面错位的解决方法
Jun 12 Javascript
jsvascript图像处理—(计算机视觉应用)图像金字塔
Jan 15 Javascript
iframe实用操作锦集
Apr 22 Javascript
Ajax局部更新导致JS事件重复触发问题的解决方法
Oct 14 Javascript
AngularJS初始化过程分析(引导程序)
Dec 06 Javascript
jquery使用slideDown实现模块缓慢拉出效果的方法
Mar 27 Javascript
Angular.JS利用ng-disabled属性和ng-model实现禁用button效果
Apr 05 Javascript
浅谈Angular4中常用管道
Sep 27 Javascript
Vue按需加载的具体实现
Dec 02 Javascript
实例详解Vue项目使用eslint + prettier规范代码风格
Aug 20 Javascript
深入理解Vue.js轻量高效的前端组件化方案
Dec 10 Javascript
Vue 中 filter 与 computed 的区别与用法解析
Nov 21 Javascript
AngularJS ui-router (嵌套路由)实例
Mar 10 #Javascript
微信小程序手势操作之单触摸点与多触摸点
Mar 10 #Javascript
Web纯前端“旭日图”实现元素周期表
Mar 10 #Javascript
微信小程序 MD5的方法详解及实例代码
Mar 10 #Javascript
jQuery实现扑克正反面翻牌效果
Mar 10 #Javascript
AngularJS之页面跳转Route实例代码
Mar 10 #Javascript
Angular多选、全选、批量选择操作实例代码
Mar 10 #Javascript
You might like
php 将excel导入mysql
2009/11/09 PHP
PHP获取url的函数代码
2011/08/02 PHP
PHP处理SQL脚本文件导入到MySQL的代码实例
2014/03/17 PHP
php发送邮件的问题详解
2015/06/22 PHP
Yii2 加载css、js 载静态资源的方法
2017/03/10 PHP
PHP闭包定义与使用简单示例
2018/04/13 PHP
基于JavaScript实现移动端点击图片查看大图点击大图隐藏
2015/11/04 Javascript
详解JavaScript的流程控制语句
2015/11/30 Javascript
jQuery给元素添加样式的方法详解
2015/12/30 Javascript
jquery点击改变class并toggle的实现代码
2016/05/15 Javascript
JS控制TreeView的结点选择
2016/11/11 Javascript
快速实现jQuery多级菜单效果
2017/02/01 Javascript
vue 文件目录结构详解
2017/11/24 Javascript
VSCode 配置React Native开发环境的方法
2017/12/27 Javascript
解决vue打包之后静态资源图片失效的问题
2018/02/21 Javascript
浅谈Vue-cli单文件组件引入less,sass,css样式的不同方法
2018/03/13 Javascript
基于layui框架响应式布局的一些使用详解
2019/09/16 Javascript
VUE+elementui面包屑实现动态路由详解
2019/11/04 Javascript
js刷新页面location.reload()用法详解
2019/12/09 Javascript
vue实现给div绑定keyup的enter事件
2020/07/31 Javascript
用python实现批量重命名文件的代码
2012/05/25 Python
Python高效编程技巧
2013/01/07 Python
Python使用Dijkstra算法实现求解图中最短路径距离问题详解
2018/05/16 Python
Python干货:分享Python绘制六种可视化图表
2018/08/27 Python
python 计算平均平方误差(MSE)的实例
2019/06/29 Python
Python单元测试工具doctest和unittest使用解析
2019/09/02 Python
python使用turtle库绘制奥运五环
2020/02/24 Python
怎么写好自荐信
2013/10/30 职场文书
《青海高原一株柳》教学反思
2014/04/25 职场文书
关于读书的演讲稿300字
2014/08/27 职场文书
村党支部书记个人对照材料汇报
2014/10/26 职场文书
运动会新闻报道稿
2015/07/22 职场文书
2016党员入党决心书
2015/09/22 职场文书
《花钟》教学反思
2016/02/17 职场文书
2019新员工心得体会
2019/06/25 职场文书
漫画「你在春天醒来」第10卷封面公开
2022/03/21 日漫