1

可能重复:
在 JavaScript 中获取查询字符串值

我正在开发 Chrome 的扩展程序。我已经想出了如何从实际的 Chrome-Tab 中获取 URL。

chrome.tabs.getSelected(null, function(tab) {
  document.getElementById('currentLink').innerHTML = tab.url;
});

但现在我需要知道如何从 URL 中获取特定的参数。我已经尝试过不同的 Javascript 函数,但是当我实现它们时,我的扩展程序停止工作。

那么:如何从实际 URL 中获取特定参数?

4

3 回答 3

4

要在单个正则表达式中获取查询字符串,请使用:

var queryString = /^[^#?]*(\?[^#]+|)/.exec(tab.url)[1];
// Explanation of RegEx:
// ^[^#?]*                          (\?[^#]+   | )
// <Starts with any non-#/? string><query string OR nothing>

然后,使用以下函数获取特定键的值:

function getParameterByName(queryString, name) {
    // Escape special RegExp characters
    name = name.replace(/[[^$.|?*+(){}\\]/g, '\\$&');
    // Create Regular expression
    var regex = new RegExp("(?:[?&]|^)" + name + "=([^&#]*)");
    // Attempt to get a match
    var results = regex.exec(queryString);
    return decodeURIComponent(results[1].replace(/\+/g, " ")) || '';
}

// Usage:
// Example: tab.url = "http://example.com/path?foo=bar&key_name=qs_value#"
var queryString = /\?[^#]+(?=#|$)|$/.exec(tab.url)[0];
var value = getParameterByName(queryString, 'qs_name');
// Result : value = "value";

// Example 2: Using the function to get a parameter from the current page's URL.
//  (e.g inside content script)
var value = getParameterByName(location.search, 'qs_name');
// Result : value = "value"
于 2012-08-02T09:49:59.873 回答
0

不完全是正则表达式,但这应该有效:

var queryString=url.match(/\?.+$)[0].split('#')[0]

这在大多数情况下应该有效。我将尝试挖掘我前段时间为此编写的正则表达式。

于 2012-08-02T09:31:38.857 回答
0

创建了简单的函数来从这样的 URL 获取 Javascript 中的 URL 参数

.....58e/web/viewer.html?page= 17 &getinfo= 33

    function buildLinkb(param) {
        var val = document.URL;
        var url = val.substr(val.indexOf(param))  
        var n=parseInt(url.replace(param+"=",""));
        alert(n+1); 
    }
    buildLinkb("page");

输出:18

于 2012-08-04T12:00:01.510 回答