Javascript window.open передать значения с помощью POST - PullRequest
59 голосов
/ 16 апреля 2011

У меня есть функция javascript, которая использует window.open для вызова другой страницы и возврата результата.

Вот раздел моего кода:

var windowFeatures = "status=0, toolbar=0, location=0, menubar=0, directories=0, resizable=1, scrollbars=1";
window.open ('http://www.domain.com/index.php?p=view.map&coords=' + encodeURIComponent(coords), 'JobWindow', windowFeatures);

Моя проблема сейчас в том, что я передаю много данных для обработки GET, и мне нужно передать их, используя метод POST.

Как я могу преобразовать приведенный выше код, чтобы открыть страницу, используя метод POST без применения форм по всей странице (на странице перечислены 100 заказов со списком поставщиков - я пытаюсь сопоставить поставщиков)

Ответы [ 6 ]

64 голосов
/ 17 апреля 2011

Я использовал вариант, описанный выше, но вместо печати html я построил форму и отправил ее на сторонний URL:

    var mapForm = document.createElement("form");
    mapForm.target = "Map";
    mapForm.method = "POST"; // or "post" if appropriate
    mapForm.action = "http://www.url.com/map.php";

    var mapInput = document.createElement("input");
    mapInput.type = "text";
    mapInput.name = "addrs";
    mapInput.value = data;
    mapForm.appendChild(mapInput);

    document.body.appendChild(mapForm);

    map = window.open("", "Map", "status=0,title=0,height=600,width=800,scrollbars=1");

if (map) {
    mapForm.submit();
} else {
    alert('You must allow popups for this map to work.');
}
38 голосов
/ 13 июня 2013

Спасибо php-b-grader .Я улучшил код, нет необходимости использовать window.open () , цель уже указана в форме .

// Create a form
var mapForm = document.createElement("form");
mapForm.target = "_blank";    
mapForm.method = "POST";
mapForm.action = "abmCatalogs.ftl";

// Create an input
var mapInput = document.createElement("input");
mapInput.type = "text";
mapInput.name = "variable";
mapInput.value = "lalalalala";

// Add the input to the form
mapForm.appendChild(mapInput);

// Add the form to dom
document.body.appendChild(mapForm);

// Just submit
mapForm.submit();

для целевых вариантов -> w3schools - Target

18 голосов
/ 19 апреля 2017

Что стоит, вот ранее предоставленный код, инкапсулированный в функции.

openWindowWithPost("http://www.example.com/index.php", {
    p: "view.map",
    coords: encodeURIComponent(coords)
});

Определение функции:

function openWindowWithPost(url, data) {
    var form = document.createElement("form");
    form.target = "_blank";
    form.method = "POST";
    form.action = url;
    form.style.display = "none";

    for (var key in data) {
        var input = document.createElement("input");
        input.type = "hidden";
        input.name = key;
        input.value = data[key];
        form.appendChild(input);
    }

    document.body.appendChild(form);
    form.submit();
    document.body.removeChild(form);
}
6 голосов
/ 13 января 2014

спасибо php-b-grader!

ниже обобщенной функции для значений передачи window.open с использованием POST:

function windowOpenInPost(actionUrl,windowName, windowFeatures, keyParams, valueParams) 
{
    var mapForm = document.createElement("form");
    var milliseconds = new Date().getTime();
    windowName = windowName+milliseconds;
    mapForm.target = windowName;
    mapForm.method = "POST";
    mapForm.action = actionUrl;
    if (keyParams && valueParams && (keyParams.length == valueParams.length)){
        for (var i = 0; i < keyParams.length; i++){
        var mapInput = document.createElement("input");
            mapInput.type = "hidden";
            mapInput.name = keyParams[i];
            mapInput.value = valueParams[i];
            mapForm.appendChild(mapInput);

        }
        document.body.appendChild(mapForm);
    }


    map = window.open('', windowName, windowFeatures);
if (map) {
    mapForm.submit();
} else {
    alert('You must allow popups for this map to work.');
}}
2 голосов
/ 05 февраля 2015

Несмотря на то, что этот вопрос был давно, спасибо всем за вклады, которые помогли мне решить подобную проблему.Я также сделал небольшую модификацию, основанную на ответах других здесь и сделав несколько входов / ценностей в один объект (json);и надеюсь, что это кому-то поможет.

js:

//example: params={id:'123',name:'foo'};

mapInput.name = "data";
mapInput.value = JSON.stringify(params); 

php:

$data=json_decode($_POST['data']); 

echo $data->id;
echo $data->name;
1 голос
/ 04 февраля 2015

Код помог мне выполнить мое требование.

Я внес некоторые изменения и, используя форму, заполнил. Вот мой код -

Нужен атрибут 'target' для 'form' - вот и все!

Форма

<form id="view_form" name="view_form" method="post" action="view_report.php"  target="Map" >
  <input type="text" value="<?php echo $sale->myvalue1; ?>" name="my_value1"/>
  <input type="text" value="<?php echo $sale->myvalue2; ?>" name="my_value2"/>
  <input type="button" id="download" name="download" value="View report" onclick="view_my_report();"   /> 
</form>

JavaScript

function view_my_report() {     
   var mapForm = document.getElementById("view_form");
   map=window.open("","Map","status=0,title=0,height=600,width=800,scrollbars=1");

   if (map) {
      mapForm.submit();
   } else {
      alert('You must allow popups for this map to work.');
   }
}

Полный код поясняется с указанием нормальной формы и элементов формы.

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