乐趣区

关于javascript:js解析url的三种方法

js 解析 url,将如下 url 中的参数解析为 key-value 对象
https://mp.weixin.qq.com/adva…

办法 1,split() + 循环顺次取出

parseURLParams(url) {let queryParams = {}
    // 判断是否有参数
    if (url.indexOf('?') < 0) return queryParams
    // 拆散域名和参数
    let domainAndParams = url.split('?')
    // 参数切分
    let queryStr = domainAndParams[1]
    let queryItems = queryStr.split('&')
    // 循环参数,把参数转为键值对
    queryItems.forEach(item => {let paramKV = item.split('=')
        queryParams[paramKV[0]] = paramKV[1]
    })
    // 返回参数键值对
    return queryParams
}

办法 2,正则 + arguments

parseURLParams(url) {let queryParams = {}
    // 正则匹配规定
    let reg = /([^?=&]+)=([^?=&]+)/g
    // 利用 replace 替换
    url.replace(reg, function() {
        // 用伪数组进行键值对拼接
        queryParams[arguments[1]] = arguments[2]
    })
    // 返回参数键值对
    return queryParams
}

办法 3,正则 + …arg

parseURLParams(url) {let queryParams = {}
    // 正则匹配规定
    let reg = /([^?=&]+)=([^?=&]+)/g
    // 利用 replace 替换
    url.replace(reg, function() {
        // 用伪数组进行键值对拼接
        queryParams[arguments[1]] = arguments[2]
    })
    // 返回参数键值对
    return queryParams
退出移动版