提问者:小点点

XMLHttpRequest POST formData到新选项卡[重复]


由于loadOneTab()不适用于formData

  1. 如何将formData发布到新选项卡?
  2. 如何设置上述新标签前台/后台状态?

只是使用FormData对象的一个简单示例:

var formData = new FormData();

formData.append("username", "Groucho");
formData.append("accountnum", 123456); // number 123456 is immediately converted to string "123456"

// HTML file input user's choice...
formData.append("userfile", fileInputElement.files[0]);

// JavaScript file-like object...
var content = '<a id="a"><b id="b">hey!</b></a>'; // the body of the new file...
var blob = new Blob([content], { type: "text/xml"});

formData.append("webmasterfile", blob);

var request = new XMLHttpRequest();
request.open("POST", "http://foo.com/submitform.php");
request.send(formData);

澄清:
带有target="_blank"的普通超文本标记语言表单将表单数据发布到新选项卡。
类似地,如前所述,loadOneTab()也可以将数据发布到新选项卡。
使用XMLHttpRequest是否可以做到这一点?


共2个答案

匿名用户

XHR与选项卡完全无关。如果您真的想XHR它,那么您应该将目标选项卡的返回源和更新文档与它一起使用。

否则我只会使用loadOneTab:我会想这样的事情变成nsIFile:

在这里导入codeFormData函数形式:https://stackoverflow.com/a/25020668/3791822

// HTML file input user's choice...
var userfileNSIFILE = new FileUtils.File(fileInputElement.files[0].path);

// JavaScript file-like object...
var content = '<a id="a"><b id="b">hey!</b></a>'; // the body of the new file...
var blob = new Blob([content], { type: "text/xml"});

//some code here to write blob to temp folder to make nsifile or do some stream stuff to get an nisfileoutputstream?
var blobNSIFILE = ....;

let postData = encodeFormData({
  "webmasterfile": blobNSIFILE,
  "userfile": userfileNSIFILE,
  "username": "Groucho",
  "accountnum": 123456
}, "iso8859-1");

gBrowser.loadOneTab("http://foo.com/submitform.php", {
  inBackground: false,
  postData: postData
});

匿名用户

这就是我所说的将xhr的响应文本加载到选项卡中,可以将粘贴复制到便笺簿。

var xhr = new XMLHttpRequest();
    xhr.onreadystatechange = function() {
        switch (xhr.readyState) {
                case 4:
                   prompt('done', xhr.responseText);
                    gBrowser.loadOneTab('data:text/html, ' + encodeURIComponent(xhr.responseText), {
                      inBackground: false
                    });
            break;
          default:
        }
    };
    xhr.open("GET", "https://www.bing.com/");
    xhr.send();