angular学习笔记(十七)-路由和切换视图

本篇介绍angular中如何通过判断url的hash值来显示不同的视图模板,并使用不同的控制器:

下面,通过一个例子,来一步一步说明它的用法:

我们要做一个邮箱应用,打开的时候显示的是邮件列表:

然后点击邮件主题,可以查看该邮件的详细内容:

点击返回列表,再回到列表页

一.
创建index页面:


<!DOCTYPE html>
<html>
<head>
<title>14.1路由和视图切换</title>
<meta charset="utf-8">
<script src="../../angular.js"></script>
<script src="controller.js"></script>
<link type="text/css" href="style.css" rel="stylesheet" />
</head>
<body>
<div ng-app="A-Mail">
<h3>A-Mail</h3>
<br>
<div ng-view></div>
</div>
</body>
</html>

这一步需要做的事情有:

①. 通过ng-app,使用某个模型来管理页面

②. 通过ng-view,创建空的div,里面的内容会根据url的hash值来调用不同的视图模板,并且使用不同的控制器

③. 写好公共的,始终被显示的视图部分,比如这里的标题: <h3>A-Mail</h3>

二. 创建需要被调用的其它视图,
也就会是放在ng-view中的视图模板:

①list.html:


<table>
<tr><th>发件人</th><th>主题</th><th>发送时间</th></tr>
<tr ng-repeat="message in messages">
<td>{{message.sender}}</td><td><a href="#/view/{{message.id}}">{{message.subject}}</a></td><td>{{message.date}}</td>
</tr>
</table>

当hash值为空的时候,ng-view中应该显示的是邮件的列表.

注意,其中邮件的链接应该使用"#/..." 使用#开头表示改变路径的hash值

比如我输入这个链接:

http://localhost:801/angular/OREILLY/14.1.路由和视图切换/index.html

打开后,它会自己变成:

http://localhost:801/angular/OREILLY/14.1.路由和视图切换/index.html#/

如果跳转到"#/view/001",

url就会变成: http://localhost:801/angular/OREILLY/14.1.路由和视图切换/index.html#/view/001

②detail.html:


<p><b>主题:</b><span>{{message.subject}}</span></p>
<p><b>发件人:</b><span>{{message.sender}}</span></p>
<p><b>发送时间:</b><span>{{message.date}}</span></p>
<h4>To:</h4>
<ul class="clear_float"><li ng-repeat="name in message.recipients">{{name}}; </li></ul>
<hr>
<div>{{message.content}}</div>
<a class="button" href="#/">返回列表</a>

当hash值为view/id的时候,显示的应该是当前id的邮件详细内容

返回列表按钮返回到没有hash值的路径

三.
创建模块,路由,控制器:


var messages = [
{
"id":"001",
"sender":"兔小宝",
"subject":"给小宝买草",
"date":"Dec 7, 2014 12:32:00",
"recipients": ["小a","米米","小黑"],
"content":"今天一定要给我买草啊!!!"
},
{
"id":"002",
"sender":"周孝刚",
"subject":"给小宝加水",
"date":"May 12, 2014 05:04:00",
"recipients": ["兔兔","粥粥","小白"],
"content":"今天一定要给小宝加水啊!!!"
},
{
"id":"003",
"sender":"code_bunny",
"subject":"买凉席",
"date":"Thu 14, 2014 04:14:00",
"recipients": ["white_bunny","sb","小米"],
"content":"今天一定要给买凉席啊!!!"
}
];

var aMail = angular.module(‘A-Mail‘,[]);

aMail.controller(‘listControll‘,function($scope){
$scope.messages = messages;
});
aMail.controller(‘detailControll‘,function($scope, $routeParams){
var index = parseInt($routeParams.id)-1;
$scope.message = messages[index];
});

aMail.config(function($routeProvider){
$routeProvider.when(‘/‘,{controller:‘listControll‘,templateUrl:‘view/list.html‘}).when(‘/view/:id‘,{controller:‘detailControll‘,templateUrl:‘view/detail.html‘}).otherwise({redirectTo:‘/‘})
});

①.messages是虚拟的数据

②.创建该应用使用的模型

③.给该模型创建两个控制器,分别用于控制邮件列表视图和邮件详细内容视图

④.给该模型配置路由:

aMail.config(function($routeProvider){

$routeProvider.when(‘hash1‘,{controller:‘someController1‘,templateUrl:‘path/to/view1}).when(‘hash2‘,{controller:‘someController2‘,templateUrl:‘path/to/view2‘})....when().otherwise({redirectTo:‘/‘})

})

config方法传入一个函数,函数中传入参数"$routeProvider"作为服务.

$routeProvider.when(hash,obj)用于配置路由:

  hash: 字符串格式.
匹配url的hash值,注意这里不要#, ‘/‘ 就表示hash值为空.

  obj:
一个json对象,对象有以下这些属性:

    controller: ‘控制器‘    :
字符串格式,定义控制ng-view元素的控制器

  template: ‘视图模板‘  :
字符串格式,定义ng-view元素下应该使用哪个视图模板来填充内容,写的是视图模板的路径

  redirectTo: ‘路径‘     :
字符串格式,定义重定向到哪里,注意定义的也是hash值

$routeProvider.otherwise()用于当没有匹配到任何路由的时候执行的内容:

参数和when的第二个参数用法一致

⑤.$routeParams服务:

关于服务的概念,可以参考这篇:http://www.cnblogs.com/liulangmao/p/3727808.html

$routeParems可以获取到一个参数化的url组件.这个组件比较复杂,单就这个例子来看,我们在配置路由的时候在when的url属性传入了/view/:id作为匹配,这样,就会把‘view/‘后面的内容,作为$routeParems对象的id属性值

angular学习笔记(十七)-路由和切换视图

时间: 2024-12-24 12:12:25

angular学习笔记(十七)-路由和切换视图的相关文章

Ionic学习笔记4_ionic路由(页面切换)

1.1.  ionic路由机制: 状态 1.2.  ion-nav-view <body ng-controller="firstCtrl"> <a class="button" ui-sref="map">map</a> <a class="button" ui-sref="music">music</a> <a class="b

angular学习笔记(二十七)-$http(5)-使用$http构建RESTful架构

在angular中有一个特别为RESTful架构而定制的服务,是在$http的基础上进行了封装. 但是为了学习,我们先看看用直接$http是如何构建RESTful架构的: 假设有一个银行卡的列表.需要的功能有: 可以通过id来获取用户123的指定id的卡     'GET'  'card/user/123/id' 可以获取用户123的所有的银行卡             'GET'  'card/user/123' 可以更新用户123的指定id的卡                'POST' '

ASP.Net MVC开发基础学习笔记:三、Razor视图引擎、控制器与路由机制学习

一.天降神器“剃须刀” — Razor视图引擎 1.1 千呼万唤始出来的MVC3.0 在MVC3.0版本的时候,微软终于引入了第二种模板引擎:Razor.在这之前,我们一直在使用WebForm时代沿留下来的ASPX引擎或者第三方的NVelocity模板引擎. Razor在减少代码冗余.增强代码可读性和Visual Studio智能感知方面,都有着突出的优势.Razor一经推出就深受广大ASP.Net开发者的喜爱. 1.2 Razor的语法 (1)Razor文件类型:Razor支持两种文件类型,分

angular学习笔记(二十八-附2)-$resource中的promise对象

下面这种promise的用法,我从第一篇$http笔记到$resource笔记中,一直都有用到: HttpREST.factory('cardResource',function($resource){ return $resource('/card/user/:userID/:id',{userID:123,id:'@id'},{charge:{method:'POST',params:{charge:true},isArray:false}}) }); HttpREST.factory('h

angular学习笔记(八)

本篇介绍angular控制视图的显示和隐藏: 通过给元素添加ng-show属性或者ng-hide属性来控制视图的显示或隐藏: ng-show: 绑定的数据值为true时,显示元素,值为false时,隐藏元素 ng-hide: 绑定的数据值为true时,隐藏元素,值为false时,显示元素 (其实只要用到其中一个就可以了) 下面来看个简单的例子,点击按钮可以显示/隐藏元素: <!DOCTYPE html> <html ng-app> <head> <title>

angular学习笔记(二十八)-$http(6)-使用ngResource模块构建RESTful架构

ngResource模块是angular专门为RESTful架构而设计的一个模块,它提供了'$resource'模块,$resource模块是基于$http的一个封装.下面来看看它的详细用法 1.引入angular-resource.min.js文件 2.在模块中依赖ngResourece,在服务中注入$resource var HttpREST = angular.module('HttpREST',['ngResource']); HttpREST.factory('cardResource

angular学习笔记(一)

入门实例: 一个购物车产品清单,可以自行改变数量,总价自动计算的小例子: 代码如下: <!DOCTYPE html> <html ng-app> <head> <title>1.1实例:购物车</title> <meta charset="utf-8"> <script src="../angular.js"></script> <script src="

angular学习笔记(三十)-指令(5)-link

这篇主要介绍angular指令中的link属性: link:function(scope,iEle,iAttrs,ctrl,linker){ .... } link属性值为一个函数,这个函数有五个参数:scope,iEle,iAttrs,ctrl,linker scope:指令所在的作用域,这个scope和指令定义的scope是一致的.至于指令的scope,会在讲解scope属性的时候详细解释 iEle:指令元素的jqLite封装.(也就是说iEle可以调用angular封装的简版jq的方法和属

angular学习笔记(三十)-指令(2)

本篇主要讲解指令中的 restrict属性, replace属性, template属性 这三个属性 一. restrict: 字符串.定义指令在视图中的使用方式,一共有四种使用方式: 1. 元素: E 2. 属性: A 3. 样式类: C 4. 注释: M restrict的值可以是上面四个字母的任意一个或多个的组合. 不指定的话默认为A. 二. replace: 布尔值.是否将指令元素替换,可以有两个值: 1.true: 替换整个使用指令的元素 2.false: 不替换整个使用指令的元素,而