Improve this Doc View Source $location
- $locationProvider
- service in module ng
Overview
The $location service parses the URL in the browser address bar (based on the window.location) and makes the URL available to your application. Changes to the URL in the address bar are reflected into $location service and changes to $location are reflected into the browser address bar.
The $location service:
- Exposes the current URL in the browser address bar, so you can
- Watch and observe the URL.
- Change the URL.
- Synchronizes the URL with the browser when the user
- Changes the address bar.
- Clicks the back or forward button (or clicks a History link).
- Clicks on a link.
- Represents the URL object as a set of methods (protocol, host, port, path, search, hash).
For more information see Developer Guide: Using $location
Dependencies
Methods
-
absUrl();
This method is getter only.
Return full URL representation with all segments encoded according to rules specified in RFC 3986.
// given URL http://example.com/#/some/path?foo=bar&baz=xoxo var absUrl = $location.absUrl(); // => "http://example.com/#/some/path?foo=bar&baz=xoxo"
Returns
stringfull URL
-
url([url]);
This method is getter / setter.
Return URL (e.g.
/path?a=b#hash) when called without any parameter.Change path, search and hash, when called with parameter and return
$location.// given URL http://example.com/#/some/path?foo=bar&baz=xoxo var url = $location.url(); // => "/some/path?foo=bar&baz=xoxo"
Parameters
Param Type Details url (optional)stringNew URL without base prefix (e.g.
/path?a=b#hash)Returns
stringurl
-
protocol();
This method is getter only.
Return protocol of current URL.
// given URL http://example.com/#/some/path?foo=bar&baz=xoxo var protocol = $location.protocol(); // => "http"
Returns
stringprotocol of current URL
-
host();
This method is getter only.
Return host of current URL.
Note: compared to the non-AngularJS version
location.hostwhich returnshostname:port, this returns thehostnameportion only.// given URL http://example.com/#/some/path?foo=bar&baz=xoxo var host = $location.host(); // => "example.com" // given URL http://user:[email protected]:8080/#/some/path?foo=bar&baz=xoxo host = $location.host(); // => "example.com" host = location.host; // => "example.com:8080"
Returns
stringhost of current URL.
-
port();
This method is getter only.
Return port of current URL.
// given URL http://example.com/#/some/path?foo=bar&baz=xoxo var port = $location.port(); // => 80
Returns
Numberport
-
path([path]);
This method is getter / setter.
Return path of current URL when called without any parameter.
Change path when called with parameter and return
$location.Note: Path should always begin with forward slash (/), this method will add the forward slash if it is missing.
// given URL http://example.com/#/some/path?foo=bar&baz=xoxo var path = $location.path(); // => "/some/path"
Parameters
Param Type Details path (optional)stringnumberNew path
Returns
stringobjectpath if called with no parameters, or
$locationif called with a parameter -
search(search, [paramValue]);
This method is getter / setter.
Return search part (as object) of current URL when called without any parameter.
Change search part when called with parameter and return
$location.// given URL http://example.com/#/some/path?foo=bar&baz=xoxo var searchObject = $location.search(); // => {foo: 'bar', baz: 'xoxo'} // set foo to 'yipee' $location.search('foo', 'yipee'); // $location.search() => {foo: 'yipee', baz: 'xoxo'}Parameters
Param Type Details search stringObject.<string>Object.<Array.<string>>New search params - string or hash object.
When called with a single argument the method acts as a setter, setting the
searchcomponent of$locationto the specified value.If the argument is a hash object containing an array of values, these values will be encoded as duplicate search parameters in the URL.
paramValue (optional)stringNumberArray.<string>booleanIf
searchis a string or number, thenparamValuewill override only a single search property.If
paramValueis an array, it will override the property of thesearchcomponent of$locationspecified via the first argument.If
paramValueisnull, the property specified via the first argument will be deleted.If
paramValueistrue, the property specified via the first argument will be added with no value nor trailing equal sign.Returns
ObjectIf called with no arguments returns the parsed
searchobject. If called with one or more arguments returns$locationobject itself. -
hash([hash]);
This method is getter / setter.
Returns the hash fragment when called without any parameters.
Changes the hash fragment when called with a parameter and returns
$location.// given URL http://example.com/#/some/path?foo=bar&baz=xoxo#hashValue var hash = $location.hash(); // => "hashValue"
Parameters
Param Type Details hash (optional)stringnumberNew hash fragment
Returns
stringhash
-
replace();
If called, all changes to $location during the current
$digestwill replace the current history record, instead of adding a new one. -
state([state]);
This method is getter / setter.
Return the history state object when called without any parameter.
Change the history state object when called with one parameter and return
$location. The state object is later passed topushStateorreplaceState.NOTE: This method is supported only in HTML5 mode and only in browsers supporting the HTML5 History API (i.e. methods
pushStateandreplaceState). If you need to support older browsers (like IE9 or Android < 4.0), don't use this method.Parameters
Param Type Details state (optional)objectState object for pushState or replaceState
Returns
objectstate
Events
-
$locationChangeStart
Broadcasted before a URL will change.
This change can be prevented by calling
preventDefaultmethod of the event. See$rootScope.Scopefor more details about event object. Upon successful change $locationChangeSuccess is fired.The
newStateandoldStateparameters may be defined only in HTML5 mode and when the browser supports the HTML5 History API.Type:
broadcastTarget:
root scopeParameters
Param Type Details angularEvent ObjectSynthetic event object.
newUrl stringNew URL
oldUrl (optional)stringURL that was before it was changed.
newState (optional)stringNew history state object
oldState (optional)stringHistory state object that was before it was changed.
-
$locationChangeSuccess
Broadcasted after a URL was changed.
The
newStateandoldStateparameters may be defined only in HTML5 mode and when the browser supports the HTML5 History API.Type:
broadcastTarget:
root scopeParameters
Param Type Details angularEvent ObjectSynthetic event object.
newUrl stringNew URL
oldUrl (optional)stringURL that was before it was changed.
newState (optional)stringNew history state object
oldState (optional)stringHistory state object that was before it was changed.
© 2010–2018 Google, Inc.
Licensed under the Creative Commons Attribution License 4.0.
https://code.angularjs.org/1.7.8/docs/api/ng/service/$location