获取两个网址参数 - 但需要保留&符号

时间:2017-02-13 17:58:42

标签: javascript url-parameters uriencoding

我需要从一个URL中获取两个参数,并且它们可以在音频上包含一个&符号或空间。作为搜索字符串的一部分。

示例:mysite.com?param1=Bower & Wilkins?param2=Speakers

我意识到Bower& Wilkins包含获取第二个参数的明显符号,但是我可以将其替换为其他参数吗?

尝试此功能时,可以轻松返回单个参数:

URL: mysite.com?param1=Bower%20&%20Wilkins

function getQueryStringValue(key) {
  return decodeURIComponent(window.location.search.replace(new RegExp("^(?:.*[&\\?]" + encodeURIComponent(key).replace(/[\.\+\*]/g, "\\$&") + "(?:\\=([^]*))?)?.*$", "i"), "$1"));
}
var param1 = getQueryStringValue("param1"); // Bower & Wilkins

如何获取第二个参数以及如何构建URL。我可以使用另一个符号而不是&列出第二个参数?

我需要什么:

var param1 = getQueryStringValue("param1"); // Bower & Wilkins

var param2 = getQueryStringValue("param2"); // Speakers

1 个答案:

答案 0 :(得分:0)

param中的&需要编码为%26。这意味着你需要替代 在通过encodeURI运行参数或在值上使用encodeURIComponent之前。

输入应为"mysite.com?param1=Bower%20%26%20Wilkins&param2=Speakers"

要获得结果,您可以尝试这样的事情

function getQueryStringValue(url, key) {
    var params = {};
    var url_params = url.split("?", 2);
    if (url_params.length > 1) {
        var param_list = url_params[1].split("&");
        param_list.map(function (param_str) {
            var kv = param_str.split("=", 2);
            params[kv[0]] = kv[1];
        });
    }
    return (key in params)? decodeURIComponent(params[key]) : ''
}

var url = "mysite.com?param1=Bower%20%26%20Wilkins&param2=Speakers";
console.log("Bower & Wilkins" === getQueryStringValue(url, "param1"));
console.log("Speakers" === getQueryStringValue(url, "param2"));
console.log("" === getQueryStringValue(url, "param3"));