Js控制URL

Js控制URL

浏览器的location对象拥有很多方便的属性用于获取当前URL的组成部分:
  • location.protocol:协议名
  • location.username:用户名
  • location.password:密码
  • location.hostname:主机名
  • location.port:端口号
  • location.host:主机名和端口号
  • location.pathname:路径
  • location.search:查询串
  • location.hash:书签名

在较新(未测试,估计是支持跨域XHR之后的)浏览器中,还有

location.origin:协议名、主机名和端口号
可以使用。


解决方案:
  1. 构造一个HTMLAnchorElement(或者HTMLAreaElement)对象。
  2. 将该对象的href设置为要解析的URL。
  3. 获得对象的相关属性。

HTML


<input type="text" id="url" value="https://github.com:8000/foo?bar#quz" />
<button id="parse">Parse</button>
<pre id="result"></pre>

JS


function parseURL(url) {
    var anchor = document.createElement('a')
    var undefined = void 0
    var parts = {
        protocol: undefined,
        host: undefined,
        port: undefined,
        hostname: undefined,
        pathname: undefined,
        search: undefined,
        hash: undefined
    }
    anchor.href = url
    for (var key in parts) {
        parts[key] = anchor[key]
    }
    return parts
}

document.getElementById('parse').onclick = function () {
    var parts = parseURL(document.getElementById('url').value)
    var text = ''
    for (var key in parts) {
        text += key + ': ' + parts[key] + '\n'
    }
    document.getElementById('result').innerText = text
}
location.origin兼容IE (IE11+才有origin属性)

if (window["context"] == undefined) {  
    if (!window.location.origin) {  
        window.location.origin = window.location.protocol + "//" + window.location.hostname +   
        (window.location.port ? ':' + window.location.port: '');  
    }  
    window["context"] = location.origin+"/V6.0";  
}  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值