路由的应用
ui.router
通过调用$stateProvider.state()
方法创建了一个简单的路由规则,包括匹配的URL和对应的模板,当我们访问http://xxxx#/abc的时候,路由规则被匹配到,对应的模板会被填到div[ui-view]中。
$stateProvider.state()
方法:
1.创建并存储一个state对象,里面包含该路由规则的所有配置信息。
2.调用$urlRouterProvider.when(...)
方法,进行路由的注册
当hash值与state.url相匹配的时候,就跳到该state
路由是怎么匹配的:
- angular在刚开始
$digest
时,$rootScope
会触发$locationChangeSuccess
事件(angular在浏览器每次hash change的时候也会触发$locationChangeSuccess
事件) - ui.router监听了
$locationChangeSuccess
事件,于是开始通过便利一系列的rules,进行路由匹配查找 - 当匹配到路由后,就通过
$state.transitionTo(state,…)
,跳转激活对应的state - 最后,完成数据请求和模板的渲染
<html>
<head>
<meta charset="utf-8">
<title>AngularJS 路由实例 - W3Cschool教程</title>
</head>
<body ng-app='routingDemoApp'>
<h2>AngularJS 路由应用</h2>
<ul>
<li><a href="#/">首页</a></li>
<li><a href="#/computers">电脑</a></li>
<li><a href="#/printers">打印机</a></li>
<li><a href="#/blabla">其他</a></li>
</ul>
<div ng-view></div>
<script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
<script src="http://apps.bdimg.com/libs/angular-route/1.3.13/angular-route.js"></script>
<script>
angular.module('routingDemoApp',['ngRoute'])
.config(['$routeProvider', function($routeProvider){
$routeProvider
.when('/',{template:'这是首页页面'})
.when('/computers',{template:'这是电脑分类页面'})
.when('/printers',{template:'这是打印机页面'})
.otherwise({redirectTo:'/'});
}]);
</script>
</body>
</html>
实例解析:
- 载入了实现路由的 js 文件:angular-route.js;
- 包含了 ngRoute 模块作为主应用模块的依赖模块;
angular.module('routingDemoApp',['ngRoute'])
- 使用 ngView 指令;
<div ng-view></div>
该 div 内的 HTML 内容会根据路由的变化而变化。
配置$routeProvider,AngularJS $routeProvider
用来定义路由规则。
module.config(['$routeProvider', function($routeProvider){
$routeProvider
.when('/',{template:'这是首页页面'})
.when('/computers',{template:'这是电脑分类页面'})
.when('/printers',{template:'这是打印机页面'})
.otherwise({redirectTo:'/'});
}]);
AngularJS 模块的 config 函数用于配置路由规则。通过使用 configAPI,我们请求把$routeProvider
注入到我们的配置函数并且使用$routeProvider.whenAPI
来定义我们的路由规则。
$routeProvider
为我们提供了 when(path,object) & otherwise(object) 函数按顺序定义所有路由,函数包含两个参数:
- 第一个参数是 URL 或者 URL 正则规则。
- 第二个参数是路由配置对象。
路由设置对象
AngularJS 路由也可以通过不同的模板来实现。
$routeProvider.when 函数的第一个参数是 URL 或者 URL 正则规则,第二个参数为路由配置对象。
路由配置对象语法规则如下:
$routeProvider.when(url, {
template: string,
templateUrl: string,
controller: string, function 或 array,
controllerAs: string,
redirectTo: string, function,
resolve: object<key, function>
});
参数说明:
-
template:
如果我们只需要在 ng-view 中插入简单的 HTML 内容,则使用该参数:
.when('/computers',{template:'这是电脑分类页面'})
-
templateUrl:
如果我们只需要在 ng-view 中插入 HTML 模板文件,则使用该参数:
$routeProvider.when('/computers', { templateUrl: 'views/computers.html', });
以上代码会从服务端获取 views/computers.html 文件内容插入到 ng-view 中。 -
controller:
function、string或数组类型,在当前模板上执行的controller函数,生成新的scope。 -
controllerAs:
string类型,为controller指定别名。 -
redirectTo:
重定向的地址。 -
resolve:
指定当前controller所依赖的其他模块。
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<script src="//apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
<script src="//apps.bdimg.com/libs/angular-route/1.3.13/angular-route.js"></script>
<script type="text/javascript">
angular.module('ngRouteExample', ['ngRoute'])
.controller('HomeController', function ($scope) { $scope.$route = $route;})
.controller('AboutController', function ($scope) { $scope.$route = $route;})
.config(function ($routeProvider) {
$routeProvider.
when('/home', {
templateUrl: 'embedded.home.html',
controller: 'HomeController'
}).
when('/about', {
templateUrl: 'embedded.about.html',
controller: 'AboutController'
}).
otherwise({
redirectTo: '/home'
});
});
</script>
</head>
<body ng-app="ngRouteExample" class="ng-scope">
<script type="text/ng-template" id="embedded.home.html">
<h1> Home </h1>
</script>
<script type="text/ng-template" id="embedded.about.html">
<h1> About </h1>
</script>
<div>
<div id="navigation">
<a href="#/home">Home</a>
<a href="#/about">About</a>
</div>
<div ng-view="">
</div>
</div>
</body>
</html>