最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

How to get anything following the domain in a url, using Javascript - Stack Overflow

programmeradmin2浏览0评论

What is the best way to get the "anything" part after the domain part, using Javascript:




For I would have to use window.location.hash. But for I would have to use window.location.pathname.

I'm using:

window.location.href.replace(window.location.origin, "").slice(1)

Are there any caveats with this solution? Is there a better way?

What is the best way to get the "anything" part after the domain part, using Javascript:

http://www.domain./anything
http://www.domain./#anything
http://www.domain./any/thing

For http://www.domain./#anything I would have to use window.location.hash. But for http://www.domain./anything I would have to use window.location.pathname.

I'm using:

window.location.href.replace(window.location.origin, "").slice(1)

Are there any caveats with this solution? Is there a better way?

Share Improve this question edited Jul 21, 2014 at 11:36 tshepang 12.5k25 gold badges97 silver badges139 bronze badges asked Oct 1, 2013 at 9:21 TechAurelianTechAurelian 5,8216 gold badges53 silver badges68 bronze badges
Add a ment  | 

2 Answers 2

Reset to default 5

window.location.pathname + window.location.search + window.location.hash

I think this one is a little bit better. You dont have to use any functions here...

Caveats:
location.origin is not supported by IE.
Other improvements: .slice is actually calling Array.prototype.slice. A method call that requires a prototype lookup is bound to be slower than accessing the element you need directly, escpeciallly in your case, where the slice method is returning an array with just 1 element anyway. So:

You could use location.pathname, but be weary: the standard reads:

pathname
This attribute represents the path ponent of the Location's URI which consists of everything after the host and port up to and excluding the first question mark (?) or hash mark (#).

but I think the easiest, most X-browser way of getting what you want is actually simply doing this:

var queryString = location.href.split(location.host)[1];
//optionally removing the leading `/`
var queryString = location.href.split(location.host)[1].replace(/^\//,'');

It's very similar to what you have now, except for the fact that I'm not using location.origin, which, as shown on MDN is not supported by MS's IE...
Another benefit is that I'm not calling Array.prototype.slice, which returns an array, and requires a prototype-lookup, which is marginally slower, too...

发布评论

评论列表(0)

  1. 暂无评论