AngularJs $location 和 $window

$locationjson

$location服务解析浏览器地址中的url(基于window.location)而且使url在应用程序中可用。将地址栏中的网址的变化反映到$location服务和$location的变化反映到浏览器地址栏。浏览器

公开浏览器地址栏中的当前网址,这样就能够:测试

1.观察和监听网址。url

2.改变网址。spa

与浏览器url同步当用户:code

1.改变地址栏的值。对象

2. 单击“后退”或“前进”按钮(或单击“历史连接”)。blog

3.点击连接。事件

表示一组方法(协议、主机、端口、路径、搜索、哈希值)的网址对象ip

依赖:$rootElement

方法

absUrl();

只能getter,返回的是完整的url。

url([url],[replace]);

getter/setter,返回当前url路径(当前url#后面的内容,包括参数和哈希值)。

protocol();

只能getter,返回当前url的协议(好比http,https)。

host();

只能getter,返回当前url的主机名。

port();

只能getter,返回当前url的端口号。

path([path]);

getter/setter, 返回当前url的子路径(也就是当前url#后面的内容,不包括参数)。

search(search,[paramValue]);

getter/setter,返回当前url的参数的序列化json对象。

hash([hash]);

getter/setter,返回当前url的哈希值。

replace();

若是被调用,当前$digest过程当中全部$location的变化将取代当前的历史记录,而不是增长新的历史记录。

state([state]);

返回当前url的历史状态对象(不包括任何参数)。

调用一个参数而且返回$location时改变历史状态对象。

事件

$locationChangeStart

在url将要被改变时广播。可使用preventDefault取消默认事件。

参数:

angularEvent:合成事件对象。

newUrl:新的url。

oldUrl:改变前的url。

newState:新的历史状态对象。

oldState:改变前的历史状态对象。

$locationChangeSuccess

在url成功的完成变化后广播。

参数:

angularEvent:合成事件对象。

newUrl:新的url。

oldUrl:改变前的url。

newState:新的历史状态对象。

oldState:改变前的历史状态对象。

使用代码:

(function(){
     angular.module('Demo', [])
     .controller('testCtrl',["$location","$scope",testCtrl]);
     function testCtrl($location,$scope) {
        var url = "http://example.com:8080/#/some/path?foo=bar&baz=xoxo#hashValue";
        $location.absUrl();// http://example.com:8080/#/some/path?foo=bar&baz=xoxo#hashValue
        $location.url();// some/path?foo=bar&baz=xoxo
        $location.protocol();// http
        $location.host();// example.com
        $location.port();// 8080
        $location.path();// /some/path
        $location.search();// {foo: 'bar', baz: 'xoxo'}
        $location.search('foo', 'yipee');
        $location.search();// {foo: 'yipee', baz: 'xoxo'}
        $location.hash();// #hashValue
        $scope.$on("$locationChangeStart", function () {
          //监听url变化,在变化前作想要的处理
        });
        $scope.$on("$locationChangeSuccess", function () {
          //监听url变化,在变化后作想要的处理
        });
     }
  }());

$location在平常开发中是颇有用的,特别是$locationChangeStart和$locationChangeSuccess,在作是否登陆判断的时候配合拦截器使用,根据拦截器返回的状态,监听url变化并在须要登陆的时候退出到登陆页面。

$window

一个浏览器窗口对象的引用。它是一个全局对象,在window中是全局可用的,可是它致使一些问题。在Angular中也常常经过$window服务提到它,所以它能够被重写、删除及测试。

$window 等同于 window。

  (function(){
     angular.module('Demo', [])
     .controller('testCtrl',["$window",testCtrl]);
     function testCtrl($window) {
         $window === window;
     }
  }());

$window对象能够用来获取浏览器窗口各项属性(如窗口高度宽度、浏览器版本等等)。

相关文章
相关标签/搜索