JavaScript:如何在没有jQuery或其他库的情况下将表单数据序列化为字符串

javascript: how to serialize form data to string without jquery or other libraries

提问人:guilin 桂林 提问时间:11/3/2010 最后编辑:Drakesguilin 桂林 更新时间:9/8/2023 访问量:8069

问:

如何以AJAX方式发布表单数据,而无需jQuery或其他库。

我想定义一个ajaxForm函数,它可以序列化表单数据和AJAX帖子,然后通过javascript回调。

如果我有下面的表格:

<form action="url" method="POST">
<table>
<tr><td>label...</td><td><input name="input1" type="text"/></td></tr>
<tr><td>label...</td><td><input name="input2" type="checkbox"/></td></tr>
<tr><td>label...</td><td><select name="input3"><options....></select></td></tr>
</table>
</form>

我通过javascript得到了form元素,然后我把form元素和callback函数传递给ajaxForm(form, callback)函数。

有人可以举个例子吗?多谢。。。。

更新:我最大的问题是如何序列化表单数据?

再次更新:感谢您的所有回复。问题已解决。

我已将jquery表单插件迁移到纯javascript。 我很高兴与你们分享。

https://github.com/guileen/ajaxform.js

button.onclick = function(){
  ajaxForm(form, function(xmlhttp){
    alert(xmlhttp.status);
    alert(xmlhttp.responseText);
  });
}
JavaScript AJAX 序列化

评论

3赞 Quentin 11/3/2010
序列化表单数据是抓取表单,正确循环其并从中提取所有数据的问题。您必须确定哪些控件是成功的(例如,单选按钮只有在未禁用并被选中时才成功)并从中获取值(对于不同类型的元素,这样做的方式不同(例如,多个选择元素很痛苦)。这是一项漫长而无聊的任务,有很多变量,而使用现有的库要好得多,因为其他人已经为你考虑了所有这些。.elements
0赞 guilin 桂林 11/3/2010
我决定将jquery ajax表单插件迁移到纯javascript。
1赞 T.Todua 12/26/2014
表单序列化 JavaScript 的可能重复(无框架)

答:

0赞 2 revs, 2 users 89%cloverink #1
var http_request = false;
function makePOSTRequest(url, parameters) {
  http_request = false;
  if (window.XMLHttpRequest) { // Mozilla, Safari,...
     http_request = new XMLHttpRequest();
     if (http_request.overrideMimeType) {
        // set type accordingly to anticipated content type
        //http_request.overrideMimeType('text/xml');
        http_request.overrideMimeType('text/html');
     }
  } else if (window.ActiveXObject) { // IE
     try {
        http_request = new ActiveXObject("Msxml2.XMLHTTP");
     } catch (e) {
        try {
           http_request = new ActiveXObject("Microsoft.XMLHTTP");
        } catch (e) {}
     }
  }
  if (!http_request) {
     alert('Cannot create XMLHTTP instance');
     return false;
  }

  http_request.onreadystatechange = alertContents;
  http_request.open('POST', url, true);
  http_request.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
  http_request.setRequestHeader("Content-length", parameters.length);
  http_request.setRequestHeader("Connection", "close");
  http_request.send(parameters);
}

function alertContents() {
  if (http_request.readyState == 4) {
     if (http_request.status == 200) {
        //alert(http_request.responseText);
        result = http_request.responseText;
        document.getElementById('myspan').innerHTML = result;            
     } else {
        alert('There was a problem with the request.');
     }
  }
}

// call me
function get(obj) {
  var poststr = "mytextarea1=" + encodeURI( document.getElementById("mytextarea1").value ) +
                "&mytextarea2=" + encodeURI( document.getElementById("mytextarea2").value );
  makePOSTRequest('post.php', poststr);
}

评论

1赞 Quentin 11/3/2010
这并没有解决问题的关键部分(根据在此答案前 20 分钟进行的编辑,并以巨大的字体显示)......它使用全局变量!至少它确实发出了 POST 请求。
-1赞 kaore 8/15/2014 #2

对于那些使用 npm 和 browserify 的人来说,这里符合要求: https://github.com/defunctzombie/form-serialize

评论

0赞 Branco 5/15/2021
这个问题确实在没有jQuery或其他库的情况下提出。