0

我需要从 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

4

1 回答 1

0

参数内&的 需要编码为%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"));
于 2017-02-13T18:24:04.323 回答