angular路由——ui.route
angular路由
###使用案例
```
test
```
`time.html`
```
金刚葫芦娃
```
路由控制器使用
- 注:不需要在html中定义控制器
var app = angular.module("myApp", ['ui.router']);
app.config(['$stateProvider','$urlRouterProvider',function($stateProvider,$urlRouterProvider){
//默认路由,与下面定义的路由匹配
$urlRouterProvider.otherwise('/lol');
//路由定义规则
$stateProvider
.state('lol', {
url:'/lol',
templateUrl: 'time.html',
controller: ['$scope',function($scope){ //直接在内部写控制器
}]
})
.state('dota', {
url:'/dota',
template: '<h1>王者荣耀</h1>',
controller: 'ctrl' //引入外部控制器
})
app.controller("ctrl", ['$scope', function($scope){
}]);
$state服务
- 实现路由中转
- 判断用户是否登录,若未登录,则跳转到登录页面
app.controller("ctrl", ['$scope','$state', function($scope,$state){
$scope.go = function(url){ //这里的方法随便命名
$state.go(url); //$state的go方法实现跳转,这个方法必须是go方法
}
time.html
<button ng-click="go('dota')">跳转</button> <!-- 这里的方法随便命名,点击后跳转到指定路由,不要加‘/ ’-->
$stateParams
- 在dota路由处加上{id},显示数据id
- 模板处加上
ui-sref="dota({id:v.id})
,实现 跳转到dota路由,并显示id
var app = angular.module("myApp", ['ui.router']);
app.config(['$stateProvider','$urlRouterProvider',function($stateProvider,$urlRouterProvider){
//默认路由,与下面定义的路由匹配
$urlRouterProvider.otherwise('/lol');
//路由定义规则
$stateProvider
.state('lol', {
url:'/lol',
templateUrl: 'time.html',
controller: ['$scope',function($scope){ //直接在内部写控制器
}]
})
.state('dota', {
url:'/dota{id}', //要加上{id},才会显示id
template: '<h1>王者荣耀</h1>',
controller: 'ctrl' //引入外部控制器
})
app.controller("ctrl", ['$scope','$stateParams', function($scope,$stateParams){
$scope.data = [
{id:1,name:"刘恺威",title:"王鸥"},
{id:2,name:"飞刀又见飞刀",title:"李元芳"}
];
var id = $stateParams.id;
if(id){
for(var i=0;i<$scope.data.length;i++){
if(id==$scope.data[i].id){
$scope.name=$scope.data[i].name;
}
}
}
}]);
time.html
<ul ng-repeat="v in data">
<li><a href="" ui-sref="dota({id:v.id})">{{v.name}}</a></li> <!-- 跳转到dota路由,并显示id -->
</ul>
<p>{{name}}</p>
父子嵌套路由
- 将父级路由模板内加入
<div ui-view></div>
,子级模板内容会在父级模板中显示,最后一起通过父级路由加载到首页的<div ui-view></div>
- 写法一
lol.dota
,父级下的路由 - 写法二
parent:lol
,指定该路由的父级
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>test</title>
</head>
<body ng-app="myApp">
<a href="" ui-sref="lol">首页</a> <!-- ui-serf的值对应state的第一个参数 -->
<a href="" ui-sref="lol.dota">游戏</a> <!-- ui-serf的值对应state的url参数 -->
<a href="" ui-sref="youku">视频</a>
<div ui-view></div> <!-- 首页的<div ui-view></div> -->
<script src="angular.min.js"></script>
<script src="jquery-3.1.1.min.js"></script>
<script src="http://cdn.bootcss.com/angular-ui-router/1.0.0-beta.3/angular-ui-router.min.js"></script>
<script>
var app = angular.module("myApp", ['ui.router']);
app.config(['$stateProvider','$urlRouterProvider',function($stateProvider,$urlRouterProvider){
//默认路由,与下面定义的路由匹配
$urlRouterProvider.otherwise('/lol');
//路由定义规则
$stateProvider
.state('lol', {
url:'/lol',
templateUrl: 'time.html',
})
.state('lol.dota', { //父级下的路由写法
url:'/lol.dota',
template: '<h1>王者荣耀</h1>',
})
.state('youku', {
url:'/youku',
template: '<h1>黑海夺金</h1>',
parent:'lol' //指定该路由的父级
})
}])
</script>
</body>
</html>
time.html
<h1>金刚葫芦娃{{name}}</h1>
<div ui-view></div> <!-- 将父级路由模板内加入<div ui-view></div>,子级模板内容会在父级模板中显示 -->
ui.route视图概念——ui-view
- 本案例效果为T字型网页,点击左侧导航栏,改变右侧显示
- views里写
ui-view
对应的视图 - 左侧模板,可以点击跳转到不同路由,从而改变右侧视图显示
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>test</title>
<style>
div[ui-view="left"]{background-color: #ccc; float:left;}
div[ui-view="right"]{}
</style>
</head>
<body ng-app="myApp">
<div ui-view="top"></div>
<div ui-view="left"></div>
<div ui-view="right"></div>
<script src="angular.min.js"></script>
<script src="jquery-3.1.1.min.js"></script>
<script src="http://cdn.bootcss.com/angular-ui-router/1.0.0-beta.3/angular-ui-router.min.js"></script>
<script>
var app = angular.module("myApp", ['ui.router']);
app.config(['$stateProvider','$urlRouterProvider',function($stateProvider,$urlRouterProvider){
//默认路由,与下面定义的路由匹配
$urlRouterProvider.otherwise('/my');
//路由定义规则
$stateProvider
.state('my', {
url:'/my',
views: { //显示ui-view中的视图
top:{templateUrl: 'time.html'},
left:{templateUrl: 'left.html'},
right:{templateUrl: 'right.html'}
}
})
.state('game', {
url:'/game',
views: {
top:{templateUrl: 'time.html'},
left:{templateUrl: 'left.html'},
right:{templateUrl: 'game.html'}
}
})
}])
</script>
</body>
</html>
time.html
<h1>童年</h1>
left.html
<div><a href="#/my">动画</a></div> <!-- 点击切换到不同的路由 -->
<div><a href="" ui-sref="game">游戏</a></div>
right.html
<h1>金刚葫芦娃</h1>
game.html
<h1>超级玛丽</h1>
angular路由——ui.route的更多相关文章
- angular路由配置以及使用
一.生成路由文件 按照惯例,有一个独立模块来配置相关路由,这个模块类的名字叫做AppRoutingModule,位于src/app下的app-routing.module.ts文件中. 使用CLI生成 ...
- angular路由详解:
1.$routeProvider ngRoute模块中的服务 2.otherwise:设置用于路由改变时,与任何其他定义的路由无法匹配的时候执行的代码 3.when:为$route服务定义新的路由 例 ...
- 阿里云 Angular 2 UI框架 NG-ZORRO介绍
说明: Angular2出来后,一直想找个基于Angular2的前端后台管理框架,但一直没有找到比较适合的.前段时间在Angular官网资源无意之间看到NG-ZORRO,NG-ZORRO由阿里计算平台 ...
- angular 路由项目例子
angular 路由是我在工作中体验非常便捷的一点, 这是详细的API ,查看API 可以了解很多东西, https://github.com/angular-ui/ui-router/wiki/Qu ...
- Angular路由守卫 canActivate
作用 canActivate 控制是否允许进入路由. canActivateChild 等同 canActivate,只不过针对是所有子路由. 关键代码 创建路由守卫 import { Injecta ...
- Angular路由守卫 canDeactivate
目的 离开页面时,做出逻辑判断 以ng-alain的项目为基础做演示 效果如图: 关键代码 定义一个CanDeactivateGuardService export class CanDeactiva ...
- Angular 路由守卫
1. 路由 Angular路由: 可以控制页面跳转:可以在多视图间切换: 2. 路由守卫 Angular路由守卫: 在进入或离开某路由时,用于判断是否可以离开.进入某路由::: return true ...
- angularjs中使用锚点,angular路由导致锚点失效的两种解决方案
壹 ❀ 引 公司新项目开发中,首页要做个楼层导航效果(如下图),要求能点击图标对应跳到楼层即可,因为不需要跳转过度动画,也要求最好别用JQ,想着原生js操作dom计算top的兼容性,想着用锚点实现算 ...
- 用于实现tab页签切换页面的angular路由复用策略
使用场景 打开菜单页面的时候,出现对应页面的页签.切换页签,原来的页面信息状态保留,关闭页签则保留的信息删除.使用路由复用策略,保存路由快照.实现效果如图所示 实现过程 概述: 1.在app.modu ...
随机推荐
- 高性能 TCP & UDP 通信框架 HP-Socket v3.4.1
HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...
- eclipse SE增加Web开发插件
最近接触了些java项目,之前安装了eclipse SE版本.没有Web开发插件,调试不了Web代码.点击“Window”--“Preference” 左边菜单栏是找不到“Server”项来配置服务器 ...
- transformjs污染了DOM?是你不了解它的强大
原文链接: https://github.com/AlloyTeam/AlloyTouch/wiki/Powerful-transformjs 写在前面 上星期在React微信群里,有小伙伴觉得tra ...
- Android中的Libraries以及Order and Export的使用。
1Add JAR 从Eclipse的现有所有工程中,添加jar包到该工程下 2Add External JARs 从Eclipse外的其他的位置,添加jar包到该工程下 3Add Variable 增 ...
- 【代码笔记】iOS-字符串的分割
一,代码. - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. ...
- 关于iPhone图片的问题。
由于iOS设备的屏幕分辨率不尽相同,有大有小,那么在不同设备中显示同一张图片,可能会造成图片被拉伸.变形,严重影响用户体验.为了让图片在不同设备中都能得到很好的显示效果,同一类图片我们一般会准备几种版 ...
- linux shell程序
shell程序介绍 1.查看我们的Linux(centos6.5为例)有多少我们可以使用的shell: [root@localhost bin]# cat /etc/shells /bin/sh /b ...
- 运行nltk示例 Resource u'tokenizers punkt english.pickle' not found解决
nltk安装完毕后,编写如下示例程序并运行,报Resource u'tokenizers/punkt/english.pickle' not found错误 import nltk sentence ...
- linux分区机制(MBR GPT)简介
- json文件
json为什么会火 参考链接 http://www.jb51.net/article/32830.htm