代码之家  ›  专栏  ›  技术社区  ›  scopeak

如何在不重新加载的情况下修改URL查询字符串

  •  1
  • scopeak  · 技术社区  · 7 年前

    我使用以下方法更改与表单上的输入/下拉列表对应的查询URL参数。目前 window.location.href history.replaceState() 而是在不重新加载的情况下修改URL?

    正则表达式函数

    function replaceQueryString(url, param, value) {
        var re = new RegExp("([?|&])" + param + "=.*?(&|$)", "i");
        if (url.match(re))
            return url.replace(re, '$1' + param + "=" + value + '$2');
        else
            return url + '&' + param + "=" + value;
    }
    

    输入更改时

    $("#input_field").on('change', function(e) {
        window.location.href = replaceQueryString(window.location.href, 'input_value', $(this).val());
    });
    

    使现代化

    domain.com/2 但我如何才能在 replaceQueryString domain.com/?input_value=2

    $("#input_field").on('change', function(e) {
         window.history.replaceState("#input_field", "input_value", $(this).val());
    });
    
    1 回复  |  直到 7 年前
        1
  •  1
  •   guest271314    7 年前

    通过 replaceQueryString() 函数到的第三个参数 .replaceState()

    window.history.replaceState({}
    , "input_value"
    , replaceQueryString(location.href, "input_value", $(this).val()));