Добавить параметр на текущий URL - PullRequest
20 голосов
/ 05 января 2012

Я бы хотел иметь маленькую кнопку с пасхальным яйцом в углу сайта проекта.При нажатии она просто перетаскивает строку на текущий URL и перезагружает страницу.

Так что, если я нахожусь: http://test.com/projects/view/134

Нажата кнопка

Перезагрузка страницы: http://test.com/projects/view/134?ts=true

Хотя я не совсем уверен, как мне поступить.

Ответы [ 10 ]

27 голосов
/ 05 января 2012

попробуйте этот код,

var separator = (window.location.href.indexOf("?")===-1)?"?":"&";
window.location.href = window.location.href + separator + "ts=true";

редактирует: чтобы избежать дублирования параметра или очень большой строки в вашем URL, вам необходимо заменить старый параметр, который уже существует.

var url=window.location.href,
    separator = (url.indexOf("?")===-1)?"?":"&",
    newParam=separator + "ts=true";
    newUrl=url.replace(newParam,"");
    newUrl+=newParam;
    window.location.href =newUrl;
23 голосов
/ 05 января 2012

Вы можете присвоить location.href значению, которое он имеет в данный момент, плюс вашу новую строку запроса:

(отредактировано для соответствия существующим строкам запроса)

$("#yourButtonId").click({
    var loc = location.href;
    if (loc.indexOf("?") === -1)
       loc += "?";
    else
       loc += "&";
    location.href = loc + "ts=true";
});

Или чтобы быть более кратким:

$("#yourButtonId").click({
    var loc = location.href;        
    loc += loc.indexOf("?") === -1 ? "?" : "&";

    location.href = loc + "ts=true";
});
6 голосов
/ 24 мая 2017

Использование:

Пример:

var url = new URL("http://foo.bar/?x=1&y=2");

// If your expected result is "http://foo.bar/?x=1&y=2&x=42"
url.searchParams.append('x', 42);

// If your expected result is "http://foo.bar/?x=42&y=2"
url.searchParams.set('x', 42);

// Build result
url.toString();
4 голосов
/ 13 февраля 2017

Полностью используйте API-интерфейс DOM location и считайте в хэше:

location.protocol + '//' + location.pathname + 
    (location.search ? location.search + '&a=b' : '?a=b') +
    location.hash;
3 голосов
/ 17 августа 2016

Я обнаружил, что предыдущие ответы отсутствуют, и поэтому здесь есть метод, который лучше обрабатывает другие параметры в текущей строке запроса

appendToQueryString = function (param, val) {
    var queryString = window.location.search.replace("?", "");
    var parameterListRaw = queryString == "" ? [] : queryString.split("&");
    var parameterList = {};
    for (var i = 0; i < parameterListRaw.length; i++) {
        var parameter = parameterListRaw[i].split("=");
        parameterList[parameter[0]] = parameter[1];
    }
    parameterList[param] = val;

    var newQueryString = "?";
    for (var item in parameterList) {
        if (parameterList.hasOwnProperty(item)) {
            newQueryString += item + "=" + parameterList[item] + "&";
        }
    }
    newQueryString = newQueryString.replace(/&$/, "");
    return location.origin + location.pathname + newQueryString;
}

Вы должны использовать location.href = appendToQueryString(ts, true) для перезагрузки страницы.

3 голосов
/ 05 января 2012
location.href += '?ts=true';  

Просто так.

2 голосов
/ 08 апреля 2014

Если вы хотите учесть потенциальное существование хеша "#" в URL, выполните следующие действия:

var href = location.href;
var hasQuery = href.indexOf("?") + 1;
var hasHash = href.indexOf("#") + 1;
var appendix = (hasQuery ? "&" : "?") + "ts=true";
location.href = hasHash ? href.replace("#", appendix + "#") : href + appendix;
2 голосов
/ 05 января 2012

Вы имеете в виду:


$(document).ready(function() {
    $("#yourButtonId").click(function() {
       var currentUrl = window.location.pathname + "?ts=true";
    });
});


1 голос
/ 22 сентября 2017

См. Документацию по истории API:

https://developer.mozilla.org/en-US/docs/Web/API/History_API

Пример использования:

var obj = { Title: title, Url: url }; history.pushState(obj, obj.Title, obj.Url);

0 голосов
/ 01 декабря 2016

Улучшение от ответа @Bobbzorzen, с возможностью удалять параметр, передавая только его имя:

function AlterQueryString(param, val) {
    var queryString = window.location.search.replace("?", "");
    var parameterListRaw = queryString == "" ? [] : queryString.split("&");
    var parameterList = {};
    for (var i = 0; i < parameterListRaw.length; i++) {
        var parameter = parameterListRaw[i].split("=");
        if (typeof val != 'undefined') {
            parameterList[parameter[0]] = parameter[1];
        } else if (param != parameter[0]) {
            parameterList[parameter[0]] = parameter[1];
        }
    }
    if (typeof val != 'undefined') {
        parameterList[param] = val;
    }

    var newQueryString = Object.keys(parameterList).length > 0 ? "?" : "";
    for (var item in parameterList) {
        if (parameterList.hasOwnProperty(item)) {
            newQueryString += item + "=" + parameterList[item] + "&";
        }
    }
    newQueryString = newQueryString.replace(/&$/, "");
    return location.origin + location.pathname + newQueryString;
}

Суть: https://gist.github.com/envil/bc1832503bef55ffdabb0cde32bb06f1

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...