AngularJS 视图和路由
用,我们用它设置了一个默认跳转到'/'路径的路由
低优先级指令
创建一个新的作用域;
移除上一个视图,同时上一个作用域也会被清除;
将新的作用域同当前模板关联在一起;
如果路由中有相关的定义,那么就把对应的控制器同当前作用域关联起来;
触发$viewContentLoaded事件;
如果提供了onload属性,调用该属性所指定的函数。
。
'MyController'
{}
'<div><h2>Route</h2></div>'
'views/template_name.html'
属性所指定的路径通过XHR读取视图(或者从$templateCache中读
AngularJS会将模板的内容渲染到具有ng-view指令的DOM
{
$http.get('/api').then(
response.data; },
false; }
AngularJS会将列表中的元素都注入到控制器中。如果这些依赖是
工厂,即可以是一个服务的名字,也可以是一个返回值,它是会被注入到控制器中的函
resolve会发送一个$http请求,并将data的值替换为返回结果的值。列
function(route,path,search)
AngularJS会在调用它时传入下面三个参数中:
[]).
function($routeProvider) {
'HomeController',
'views/home.html'
'InboxController',
'views/inbox.html'
'/'});
otherwise方法会在没有任何路由匹配时被调
视图的生命周期由作为一个模板开始, 它将和模型合并并最终
渲染到浏览器的DOM中。 与其他模板系统不同的是,
AngularJS使用一种独特的形式来渲染视图
HTML是声明是的, 声明式的语言适合用来编写UI。 视图不应该包含任何行
为。
因为控制器和视图没有直接的调用关系,
所以可以使多个视图对应同一个控制器。 这对“换肤” 、 适配不同设备( 比如移动设备和台式机) 、 测试, 都非常重要。
模型必须在作用域中时可以被引用, 这样才能被渲染
生成视图。 和其他框架不一样的是, Angularjs对模型本身没有任何限制和要求。
你不需要继承任何类
也不需要实现指定的方法以供调用或者改变模型。 模型可以是原生的对象哈希形式的, 也可以是完整
对象类型的。 简而言之,
模型可以是原生的Javascript对象。
用来获取页面当前的路径
$location.path();
// 返回当前路径
路由或地址
希望跳转后不能点击后退按钮, AngularJS提供了replace()
方法来实现这个功能
$location.absUrl()
$location.hash();
// 返回当前的hash片段
host() 方法用来获取URL中的主机:
$location.host();//
当前URL的主机
port() 方法用来获取URL中的端口号:
$location.port();//
当前URL的端口
protocol() 方法用来获取URL中的协议:
$location.protocol();//
当前URL的协议
search() 方法用来获取URL中的查询串:
$location.search();
//
用对象设置查询
$location.search({name:
'Ari', username: 'auser'});
$location.search('name=Ari&username=auser');
search方法可以接受两个参数
search(可选,字符串或对象)
这个参数代表新的查询参数。
hash对象的值可以是数组。
paramValue(可选,字符串)
如果search参数的类型是字符串,那么paramValue会做为该参数的值覆盖URL当中的对应
值。如果paramValue的值是null
,对应的参数会被移除掉。
url() 方法用来获取当前页面的URL:
$location.url();
// 该URL的字符串
如果调用url()
方法时传了参数,会设置并修改当前的URL,这会同时修改URL中的路径、
查询串和hash,并返回$location。
$location.url('/home?name=Ari#hashthing');
url()
方法可以接受两个参数。
url
(可选,字符串)
新的URL的基础的前缀。
replace(可选,字符串)
想要修改成的路径。
当Angular从$location服务(通过$location.path() 、 $location.search()
等)对浏览器
的地址作更新时,会触发$locationChangeStart事件。
当且仅当浏览器的地址成功变更,又没有阻止
$locationChangeStart事件的情况下,
$locationChangeSuccess事件会从$rootScope上广播出来。
资料整理,声明以上资料来源与网络
AngularJS 视图和路由的更多相关文章
- [Angularjs]视图和路由(四)
写在前面 关于angularjs的路由的概念基本上这篇就要结束了,通过学习,以及在实际项目中的实践,还是比较容易上手的.自己也通过angularjs做了一个在app上的一个模块,效果还是可以的. 系列 ...
- [Angularjs]视图和路由(二)
写在前面 上篇文章主要介绍了视图和路由的基本概念,并在文章最后举了一个简单的使用案例.这篇文章将继续学习路由的配置,及相关参数的说明. 系列文章 [Angularjs]ng-select和ng-opt ...
- [Angularjs]视图和路由(三)
写在前面 上篇文章主要介绍了路由中when方法的第二个参数,常见的几个属性,以及作用.本篇文章,将介绍和路由相关的几个常见的服务. 系列文章 [Angularjs]ng-select和ng-optio ...
- [Angularjs]视图和路由(一)
写在前面 对单页应用来讲,视图和路由的作用可以从一个视图跳转到另外一个视图,可以合理管理用户在使用过程中看到的界面. 将视图分解成布局和模版视图,并且根据用户当前访问的URL来展示对应的视图,将会是一 ...
- AngularJs多重视图和路由的使用
使用AngularJs来做多重视图和路由是在方便不过了,在开发过程中,都有许多的页面,而这些页面都有相同的部分,比如页面的头部和尾部通常都是一样的,变化的都是主体部分,还有就是一些后端管理的一些项目, ...
- AngularJS 的嵌套路由 UI-Router
AngularJS 的嵌套路由 UI-Router 本篇文章翻译自:https://scotch.io/tutorials/angular-routing-using-ui-router 演示网站请查 ...
- AngularJS ui-router (嵌套路由)
http://www.oschina.net/translate/angularjs-ui-router-nested-routes AngularJS ui-router (嵌套路由) 英文原文:A ...
- 关于AngularJs中的路由学习总结
AngularJs中的路由,应用比较广泛,主要是允许我们通过不同的url访问不同的内容,可实现多视图的单页web应用.下面看看具体怎么使用. 关于路由 通常我们的URL形式为http://jtjds ...
- [转]AngularJS ui-router (嵌套路由)
本文转自:http://www.oschina.net/translate/angularjs-ui-router-nested-routes http://www.codeproject.com/A ...
随机推荐
- java 窗体
import javax.swing.*; /** * 一个简单的java窗体例子 */ public class Test { public static void main(String[] ar ...
- Python eval 作用和风险 (string 转为dict list tuple)建议用“ast.literal_eval”
a = "[[1,2], [3,4], [5,6], [7,8], [9,0]]" b = eval(a) print b [[1, 2], [3, 4], [5, 6], [7, ...
- Vmware私有云虚拟机(CentOS 6.5 OS)之根分区扩容
注:适用于未使用lvm管理的分区,目前仅在CentOS 6.5 上操作,其他系统尚未测试,请谨慎操作 一.查看当前分区状况 [root@disk-test ~]# df -h Filesystem ...
- 圆角头像----CSS3特效
w3c:http://www.w3school.com.cn/cssref/pr_border-radius.asp 定义和用法 border-radius 属性是一个简写属性,用于设置四个 bord ...
- ios--后台返回信息有字符串和数字组成的,如何获取电话号码,让用户能够点击并且进行拨打?
-(void)callPhone:(NSString*)phoneNumber{ NSString *phoneStr=[NSString stringWithFormat:@"tel:// ...
- python MD5操作
def my_md5(str): import hashlib new_str = str.encode() #把字符串转成bytes类型 # new_str = b'%s'%str #把字符串转成b ...
- 基于Boost无锁队列实现的内存池
- 【BZOJ2238】Mst 最小生成树+LCA+堆
[BZOJ2238]Mst Description 给出一个N个点M条边的无向带权图,以及Q个询问,每次询问在图中删掉一条边后图的最小生成树.(各询问间独立,每次询问不对之后的询问产生影响,即被删掉的 ...
- do not use numbers as enumeration values
w 字段类型设置错误 有限元的判断,勿用枚举行. MySQL :: MySQL 5.7 Reference Manual :: 12.4.4 The ENUM Typehttps://dev.mysq ...
- SSL逐渐演变到TLS
w https://zh.wikipedia.org/wiki/超文本传输安全协议