如何从url查询中删除参数?

时间:2014-04-09 09:19:05

标签: javascript regex

我正在尝试从url查询字符串中删除一些参数。

我有一系列要删除的参数:

var queryParamsToRemove = ['destination','formName'];

我尝试做的是搜索网址中的每个参数,然后使用RegExp将其删除。像这样:

for (param in queryParamsToRemove){
     patt = new RegExp(param,'g');
     queryString = queryString.replace('&' + patt + '=' + /*?=&/g,'');
}

但是,由于语法问题,我认为这不起作用。

3 个答案:

答案 0 :(得分:1)

这是我经常在项目中使用的函数,它允许您获取关联数组中的所有GET参数:

function urlGet()
{   
    var t = location.search.substring(1).split('&');
    var f = new Object();
    for (var i = 0; i < t.length; i++)
    {
        var x = t[i].split('=');
        f[x[0]] = x[1];
    }
    return f;
}

您可以使用此功能获取所有参数,然后使用delete方法从数组中删除您不想要的参数。

var parameters = urlGet();
delete parameters.destination;
delete parameters.formName;

您现在只需要构建一个新的查询字符串。

var query = '?';

for (var prop in parameters) 
{
    query += prop + '=' + parameters[prop] + '&';
};

query = query.substr(0, query.length - 1);

现在,将其添加到您的基本网址,您就完成了!

答案 1 :(得分:0)

回答你真实的问题:

for (param in queryParamsToRemove){
    queryString = queryString.replace(new RegExp('[&\?]' + queryParamsToRemove[param] + '=.*(&?)', 'g'), '\1');
}

这应该有效。

否则你可以使用类似这样的函数:The $.param( ) inverse function in JavaScript / jQuery(只需从函数名中删除jQuery,你可以在没有任何库的情况下使用它。)

这样的事情:

unparam = function (value) {
    var
    // Object that holds names => values.
    params = [],
    // Get query string pieces (separated by &)
    pieces = value.split('&'),
    // Temporary variables used in loop.
    pair, i, l;

    // Loop through query string pieces and assign params.
    for (i = 0, l = pieces.length; i < l; i++) {
        pair = pieces[i].split('=', 2);
        // Repeated parameters with the same name are overwritten. Parameters
        // with no value get set to boolean true.
        params[decodeURIComponent(pair[0])] = (pair.length == 2 ?
            decodeURIComponent(pair[1].replace(/\+/g, ' ')) : true);
    }

    return params;
};

var query = unparam(querystr);
for(var i in queryParamsToRemove) {
    delete query[queryParamsToRemove[i]];
}

将查询字符串转换为数组,然后从中删除您的值并将其转换回查询字符串。如果您使用jQuery,则可以使用jQuery.param()

否则,制作自己的功能应该不会太难。

现在将查询数组转换为我们可以执行的字符串:

reparam = function (queryArray) {
    var res = [];

    for(var i in queryArray) {
        res.push(i + "=" + queryArray[i]);   
    }

    return res.join('&');
}

var queryString = reparam(query);

答案 2 :(得分:0)

好的,找到了有用的东西!

for (param in queryParamsToRemove) {
    queryString = queryString.replace(new RegExp('&(' + queryParamsToRemove[param] + '=)+((\w)*(.)*)*&', 'g'), '&');
}