Подтвердить что ты не робот

Как заменить window.open(...) на POST

В настоящее время у меня есть код, который запускает строку window.open(urlWithGetParams). Насколько мне известно, это заставит меня использовать запрос GET. Я хотел бы сделать это с помощью запроса POST. Есть ли обходной путь для этого?

Я не женат на window.open(), тоже. Я открыт для любой альтернативы, которая позволяет мне запускать новое окно через запрос POST вместо GET.

4b9b3361

Ответ 1

На самом деле я сделал для этого небольшую "библиотеку", открыв в POST новое окно:

// Arguments :
//  verb : 'GET'|'POST'
//  target : an optional opening target (a name, or "_blank"), defaults to "_self"
window.io = {
    open: function(verb, url, data, target){
        var form = document.createElement("form");
        form.action = url;
        form.method = verb;
        form.target = target || "_self";
        if (data) {
            for (var key in data) {
                var input = document.createElement("textarea");
                input.name = key;
                input.value = typeof data[key] === "object"
                    ? JSON.stringify(data[key])
                    : data[key];
                form.appendChild(input);
            }
        }
        form.style.display = 'none';
        document.body.appendChild(form);
        form.submit();
        document.body.removeChild(form);
    }
};

Пример:

io.open('POST', 'fileServer.jsp', {request: {key:"42", cols:[2, 3, 34]}});

Чтобы открыть в новом окне, установите target параметр:

io.open('POST', someURL, someArgs, 'newwin');

или чтобы каждый раз открывать новое окно/вкладку:

io.open('POST', someURL, someArgs, '_blank');

Ответ 2

Что я делаю, так это то, что я делаю javascript AJAX-сообщение, а затем беру содержимое, которое я возвращаю, и помещаю его в новое окно.

Что-то вроде этого (используя jQuery, но вы можете использовать любую реализацию AJAX):

$.post(URL, DATA, function(d){
    var new_window = window.open();
    $(new_window.document.body).append(d);
});