history.pushState() change query values

2019-01-19 00:46发布

If I have a link that is being changed with the function history.pushState({}, "", link); where my link is for example page.php?value=1&value2=2 Is there a way to just change the value2 with pushState() function instead of changing the whole link?

3条回答
萌系小妹纸
2楼-- · 2019-01-19 01:32

No, because the query string is part of the URL. If you don't truly need to pass those values for the purposes of the server, you can include them in the history's state object itself, and then you can change just the state object with pushState(). For example:

history.pushState({value: 1, value2: 2}, "Title", 'page.php');
history.pushState({value: 1, value2: 'new value'}, "Title");
查看更多
欢心
3楼-- · 2019-01-19 01:33

You can use this useful function to change a query string parameter value:

function updateParam(url, param, value)
{  
    var re = new RegExp(param+"(.+?)(&|$)","g");

    return url.replace(re, param+'='+value)  
}
查看更多
叛逆
4楼-- · 2019-01-19 01:35

If what you're trying to do is change the URL without adding an additional entry to the history object, you might try replaceState.

history.replaceState({value: 1, value2: X}, "title", "page.php");
查看更多
登录 后发表回答