在使用AJAX调用的web应用程序中,我需要提交一个请求,但在URL的末尾添加一个参数,例如:

原始URL:

http://server/myapp.php?id=10

结果URL:

http://server/myapp.php?id=10&enabled=true

寻找一个JavaScript函数,该函数通过查看每个参数来解析URL,然后添加新参数或更新值(如果已经存在).

推荐答案

您需要调整的基本实现如下所示:

function insertParam(key, value) {
    key = encodeURIComponent(key);
    value = encodeURIComponent(value);

    // kvp looks like ['key1=value1', 'key2=value2', ...]
    var kvp = document.location.search.substr(1).split('&');
    let i=0;

    for(; i<kvp.length; i++){
        if (kvp[i].startsWith(key + '=')) {
            let pair = kvp[i].split('=');
            pair[1] = value;
            kvp[i] = pair.join('=');
            break;
        }
    }

    if(i >= kvp.length){
        kvp[kvp.length] = [key,value].join('=');
    }

    // can return this or...
    let params = kvp.join('&');

    // reload page with new params
    document.location.search = params;
}

这大约是基于正则表达式或搜索的解决方案的两倍,但这完全取决于查询字符串的长度和任何匹配的索引


为了完成测试,我以慢速正则表达式方法为基准(大约慢150%)

function insertParam2(key,value)
{
    key = encodeURIComponent(key); value = encodeURIComponent(value);

    var s = document.location.search;
    var kvp = key+"="+value;

    var r = new RegExp("(&|\\?)"+key+"=[^\&]*");

    s = s.replace(r,"$1"+kvp);

    if(!RegExp.$1) {s += (s.length>0 ? '&' : '?') + kvp;};

    //again, do what you will here
    document.location.search = s;
}

Javascript相关问答推荐

如何指定1条记录1个表?

积分计算和 colored颜色 判断错误

如何提取Cypress中文本

我不知道为什么我的JavaScript没有验证我的表单

Vega中的模运算符

materialized - activeIndex返回-1

如何在使用fast-xml-parser构建ML时包括属性值?

无法在nextjs应用程序中通过id从mongoDB删除'

当点击注册页面上的注册按钮时,邮箱重复

将本机导航路由react 到导航栏中未列出的屏幕?

从包含数百行的表中获取更改后的值(以表单形式发送到后端)的正确方法是什么?

如何将多维数组插入到另一个多维数组中?

扩展类型的联合被解析为基类型

使用Nuxt Apollo在Piniastore 中获取产品细节

JavaScript是否有多个`unfined`?

SPAN不会在点击时关闭模式,尽管它们可以发送日志(log)等

如何使用<;Link>;执行与JS Reaction中的";window.Location=/GameOverDied;";类似的操作?

如何在Jest中模拟函数

为什么当雪碧的S在另一个函数中时,Phaser不能加载它?

重新渲染过多(&Q).REACT限制渲染次数以防止无限循环.使用REACT下拉菜单时