ui router 介绍
1. 路由规则
rap框架页面路由基于ui-router实现
1.1 ui-router
一个基本的路由状态如下所示:
|
路由配置: $stateProvider .state('po',{ url:'/po', abstract:false, templateUrl:'./pages/master.html', resolve:{ deps:"i am a test" }, controller:'po_controller' }) 前台界面: <div ui-view></div> |
当我们访问index.html/#/po时, ‘po’状态将被激活,同时<div ui-view></div>中的ui-view将被'./pages/master.html'填充。
1.1.1 路由说明
路由定义基本参数说明如图1‑1所示:
图1‑1 参数说明
1.1.2 嵌套结构
默认的嵌套规则是根据 分隔符 '.' 实现的,
|
$stateProvider .state('po',{ url:'/po', ... }) .state('po.input',{ url:'/input', ... }) .state('po.input.mkt',{ url:"/mkt", ... }) |
以上路由配置表示:
l 'contacts'状态将匹配"/contacts"
l 'contacts.list'状态将匹配"/contacts/list"。子状态的url是附在父状态的url之后的。
1.1.3 参数使用
1.2 URL参数
1.2.1 基本参数
通常,url动态部分被称为参数,有几个选项用于指定参数。基本参数如下:
1 |
$stateProvider |
或者,你也可以使用花括号的方式来指定参数:
1 |
// 与前面的设置方法等效 |
示例:
'/hello/'- 只匹配'/hello/'路径,没有对斜杠进行特殊处理,这种模式将匹配整个路径,而不仅仅是一个前缀。'/user/:id'- 匹配'/user/bob'、'/user/1234!!!',甚至还匹配'/user/',但是不匹配'/user'和'/user/bob/details'。第二个路径段将被捕获作为参数"id"。'/user/{id}'- 与前面的示例相同,但使用花括号语法。
1.2.2 含正则表达式的参数
使用花括号的方式可以设置一个正则表达式规则的参数:
1 |
// 只会匹配 contactId 为1到8位的数字 |
示例:
'/user/{id:[^/]*}'- 与'/user/{id}'相同'/user/{id:[0-9a-fA-F]{1,8}}'- 与前面的示例相似,但只匹配1到8为的数字和字符'/files/{path:.*}'- 匹配任何以'/files/'开始的URL路径,并且捕获剩余路径到参数'path'中。'/files/*path'- 与前面相同,捕获所有特殊的语法。
警告:不要把捕获圆括号写进正则表达式,ui-router 的 UrlMatcher 将为整个正则表达式添加捕获。
1.2.3 Query Parameters
可以通过?来指定参数作为查询参数
1 |
url: "/contacts?myParam" |
如果你需要不止一个查询参数,请用&分隔:
1 |
url: "/contacts?myParam1&myParam2" |
1.3 嵌套状态的路由控制
1.3.1 附加的方式(默认)
在嵌套状态的路由控制中,默认方式是子状态的 url 附加到父状态的 url 之后。
1 |
$stateProvider |
路由将成为:
'contacts'状态将匹配"/contacts"'contacts.list'状态将匹配"/contacts/list"。子状态的url是附在父状态的url之后的。
1.3.2 绝对路由(^)
如果你使用绝对 url 匹配的方式,那么你需要给你的url字符串加上特殊符号"^"。
1 |
$stateProvider |
路由将成为:
'contacts'状态将匹配"/contacts"'contacts.list'状态将匹配"/list"。子状态的url没有附在父状态的url之后的,因为使用了^。
1.4 $stateParams 服务
之前看到的$stateParams服务是一个对象,包含 url 中每个参数的键/值。$stateParams可以为控制器或者服务提供 url 的各个部分。
注意:$stateParams服务必须与一个控制器相关,并且$stateParams中的“键/值”也必须事先在那个控制器的url属性中有定义。
1 |
// 如果状态中 url 属性是: |
1.4.1 使用$stateParams的两个陷阱
- 只有当状态被激活并且状态的所有依赖项都被注入时,
$stateParams对象才存在。这代表你不能再状态的resolve函数中使用$stateParams对象,可以使用$state.current.params来代替。 - 在状态控制器中,
$stateParams对象只包含那些在状态中定义的参数,因此你不能访问在其他状态或者祖先状态中定义的参数。
1 |
$stateProvider.state('contacts.detail', {
|
1 |
$stateProvider.state('contacts.detail', {
|
1.5 $urlRouterProvider
$urlRouterProvider负责处理在状态配置中指定的url路由方式之外的 url 请求的路由方式。$urlRouterProvider负责监视$location,当$location改变后,$urlRouterProvider将从一个列表,一个接一个查找匹配项,直到找到。所有 url 都编译成一个UrlMatcher对象。
$urlRouterProvider有一些实用的方法,可以在module.config中直接使用。
when() for redirection 重定向
参数:
whatString | RegExp | UrlMatcher,你想重定向的传入路径handlerString | Function 将要重定向到的路径
handler 作为 String
如果handler是字符串,它被视为一个重定向,并且根据匹配语法决定重定向的地址。
1 |
app.config(function($urlRouterProvider){
|
handler 作为 Function
如果handler是一个函数,这个函数是注入一些服务的。如果$location匹配成功,函数将被调用。你可以选择性注入$match。
函数可以返回:
- falsy 表明规则不匹配,
$urlRouter将试图寻找另一个匹配 - String 该字符串作为重定向地址并且作为参数传递给
$location.url() - nothing或者任何为真的值,告诉
$urlRouterurl 已经被处理
示例:
1 |
$urlRouterProvider.when(state.url, ['$match', '$stateParams', function ($match, $stateParams) {
|
otherwise() 无效路由
参数:
pathString | Function 你想重定向url路径或者一个函数返回url路径。函数可以包含$injector和$location两个参数。
1 |
app.config(function($urlRouterProvider){
|
rule() 自定义url处理
参数:
handlerFunction 一个函数,包含$injector和$location两个服务作为参数,函数负责返回一个有效的路径的字符串。
1 |
app.config(function($urlRouterProvider){
|
1.6 $urlMatcherFactory 和 UrlMatchers
定义了url模式和参数占位符的语法。$urlMatcherFactory是在幕后被$urlRouterProvider调用,来缓存编译后的UrlMatcher对象,而不必在每次 location 改变后重新解析url。大多数用户不需要直接使用$urlMatcherFactory方法,但是在状态配置中非常实用,可以使用$urlMatcherFactory方法来生成一个UrlMatcher对象,并在状态配置中使用该对象。
1 |
var urlMatcher = $urlMatcherFactory.compile("/home/:id?param1");
|
ui router 介绍的更多相关文章
- 【原创】ui.router源码解析
Angular系列文章之angular路由 路由(route),几乎所有的MVC(VM)框架都应该具有的特性,因为它是前端构建单页面应用(SPA)必不可少的组成部分. 那么,对于angular而言,它 ...
- ngRoute 与ui.router区别
angular路由 路由 (route) ,几乎所有的 MVC(VM) 框架都应该具有的特性,因为它是前端构建单页面应用 (SPA) 必不可少的组成部分. 那么,对于 angular 而言,它自然也有 ...
- ngRoute 和 ui.router 的使用方法和区别
在单页面应用中要把各个分散的视图给组织起来是通过路由机制来实现的.本文主要对 AngularJS 原生的 ngRoute 路由模块和第三方路由模块 ui.router 的用法进行简单介绍,并做一个对比 ...
- angular : $location & $state(UI router)的关系
次序:angular 的 location会先跑 $rootScope.$on("$locationChangeStart", function (scope, newUrl, o ...
- angularjs ngRoute和ui.router对比
ngRoute模块是angularjs自带的路由模块,ui.router是一个第三方路由模块,接下来将对两者进行一个对比: ng-router(angular-router.js) ng-view n ...
- angular ui.router 路由传参数
angular已经用了一段时间了,最近在做路由,做一下笔记. 路由跳转的时候进行穿参 ui.router方式 <a ui-sref="edit({id:5})"> 编辑 ...
- AngularJS 使用 UI Router 实现表单向导
Today we will be using AngularJS and the great UI Router and the Angular ngAnimate module to create ...
- [转]AngularJS 使用 UI Router 实现表单向导
本文转自:http://www.oschina.net/translate/angularjs-multi-step-form-using-ui-router 今天我们将使用AngularJs和伟大的 ...
- [转]AngularJS+UI Router(1) 多步表单
本文转自:https://www.zybuluo.com/dreamapplehappy/note/54448 多步表单的实现 在线demo演示地址https://rawgit.com/dream ...
随机推荐
- django book
一.安装配置 1.下载地址: https://www.djangoproject.com/download/ 2.安装: tar zxvf Django-1.6.1.tar.gz && ...
- 大熊君大话NodeJS之------Net模块
一,开篇分析 从今天开始,我们来深入具体的模块学习,这篇文章是这个系列(大熊君大话NodeJS)文章的第三篇,前两篇主要是以理论为主,相信大家在前两篇的学习中, 对NodeJS也有一个基本的认识,没事 ...
- Supervisor 安装与配置
Supervisor是一个进程监控程序. 满足的需求是:我现在有一个进程需要每时每刻不断的跑,但是这个进程又有可能由于各种原因有可能中断.当进程中断的时候我希望能自动重新启动它,此时,我就需要使用到了 ...
- js DOM Element属性和方法整理
节点操作,属性 1. childNodes.children 这两个属性获取到的子节点会根据浏览器的不同而不同的,所以一定要判断下nodeType是否为1. childNodes获取到的是NodeLi ...
- embed 层级太高
它怎么就好了,凭什么就好了.为什么就好了.我到底当时是哪里写错了.怎么个情况 兼容Firefox ,IE的flash透明和flash置底代码 <object classid="clsi ...
- [译]Mongoose指南 - Schema
定义schema 用mongoose的第一件事情就应该是定义schema. schema是什么呢? 它类似于关系数据库的表结构. var mongoose = require('mongoose'); ...
- [C++基础]关于对象的创建及内存分配
测试: #include <stdio.h>#include <QDebug> class KPoint{public: KPoint(int x, int y){ nx = ...
- C++ Const引用详解
(1) 在实际的程序中,引用主要被用做函数的形式参数--通常将类对象传递给一个函数.引用必须初始化. 但是用对象的地址初始化引用是错误的,我们可以定义一个指针引用. 1 int ival ...
- MFC线程内操作主窗体 控件
CWnd* h_d2 = AfxGetApp()->GetMainWnd(); //获取主窗口的句柄 h_d2-> GetDlgItem(IDC_EDIT2)->GetWindowT ...
- maven之clean、install命令
1.进入到maven根目录,执行mvn compile命令会在根目录生成target文件(参照maven之helloworld案例),如下图: 2.执行mvn clean可将根目录下生成的target ...