ajax无刷新方式收集表单并提交表单

ajax无刷新方式收集表单有两种方式,

一个是使用html5的FormData。一个是传统的方式。

一,FormData,在主流的浏览器中可以用,IE不好用啊。

另外,FormData使用有两个条件,第一,input里面需要有name属性;第二,不需要用到header头。

<script type="text/javascript">
    //给form表单制作一个提交事件onsubmit<br />
    window.onload = function(){
        var form = document.getElementsByTagName('form')[0];
          form.onsubmit = function(evt){
          //①利用FromData表单数据对象,快速搜集表单数据
         var fd = new FormData(form);
          //alert(info);
          //②ajax把收集好的信息传递给服务器
          var xhr = new XMLHttpRequest();
          xhr.onreadystatechange = function(){
              if(xhr.readyState==4){
                  alert(xhr.responseText);
              }
          };
          xhr.open('POST','register.php');
          //xhr.setRequestHeader("content-type","application/x-www-form-urlencoded");
          xhr.send(fd);
          //阻止浏览器默认动作
          evt.preventDefault();
          //return false;
      }
    }
     
</script>

二,传统方式。

<script type="text/javascript">
    //给form表单制作一个提交事件onsubmit<br />
    window.onload = function(){
        var form = document.getElementsByTagName('form')[0];
          form.onsubmit = function(evt){
          //①收集form表单信息
          
          var username = document.getElementById('username').value;
          var userpass = document.getElementById('userpass').value;
          var useremail = document.getElementById('useremail').value;
          
          var info = 'username='+username+'&userpass='+userpass+'&useremail='+useremail;//发送请求字符串
          //alert(info);
          //②ajax把收集好的信息传递给服务器
          var xhr = new XMLHttpRequest();
          xhr.onreadystatechange = function(){
              if(xhr.readyState==4){
                  alert(xhr.responseText);
              }
          };
          xhr.open('POST','register.php');
          xhr.setRequestHeader("content-type","application/x-www-form-urlencoded");
          xhr.send(info);
          //阻止浏览器默认动作
          evt.preventDefault();
          //return false;
      }
    }
     
</script>

另外,写一个form表单。

<form name="form">
        <p>用户名:<input type="text" name="username" id="username"/></p>
        <p>密码:<input type="password" name="userpass" id="userpass"/></p>
        <p>邮箱:<input type="text" name="useremail" id="useremail"/></p>
        <p><input type="submit" value="注册"/></p>
    </form>

传值到一个php文件

<?php 
    //搜集信息
    print_r($_POST);
?>

就这么简单。

原文地址:https://www.cnblogs.com/invban/p/4874482.html