zoukankan      html  css  js  c++  java
  • ajax的序列化表单提交

    通过传统的 form 表单提交的方式上传文件

    1
    2
    3
    4
    <form id="uploadForm" action="" method="post" enctype="multipart/form-data">
       <p>上传文件:<input type ="file" name="file"/></p>
       <input type="submit" value="上传"/>
    </form>

    不过传统的 form 表单提交会导致页面刷新,但是在有些情况下,我们不希望页面被刷新,这种时候我们都是使用 Ajax 的方式进行请求的。

    使用 serialize() 对 form 表单进行序列化提交

    1
    2
    3
    4
    5
    6
    7
    8
    9
    $.ajax({
       url: "",
       type: "POST",
       data: $('#uploadForm').serialize(),
       success: function(data) {  
       },
       error: function(data) {
       }
    });

    如上,通过$('#uploadForm').serialize()可以对 form 表单进行序列化,从而将 form 表单中的所有参数传递到服务端。

    但是上述方式,只能传递一般的参数,上传文件的文件流是无法被序列化并传递的。不过如今主流浏览器都开始支持一个叫做 FormData 的对象,有了这个对象就可以轻松地使用 Ajax 方式进行文件上传了。

    使用 FormData 进行 Ajax 请求并上传文件

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    <form id="uploadForm">
       <p>上传文件:<input type="file" name="file" /></p>
       <input type="button" value="上传" onclick="upload()" />
    </form>
    function upload() {
       var formData = new FormData($("#uploadForm")[0]);
       $.ajax({
         url: '',
         type: 'POST',
         data: formData,
         async: false,
         cache: false,
         contentType: false,
         processData: false,
         success: function(data) {
         },
         error: function(data) {  
         }
       });
    }
  • 相关阅读:
    【转载】消息队列使用的四种场景介绍
    Vue项目部署打包
    创建Vue项目vue-cli &#183; Failed to download repo vuejs-templates/webpack: connect ETIMEDOUT
    数据库错误:ORA-12154
    oracle数据库一条sql语句批量插入数据
    Linux time scap
    winscp不能使用root登录
    Linux find ./ -name *.bak | xargs rm -rf
    Linux命令echo 3 > /proc/sys/vm/drop_caches
    redis查看服务器占用端口
  • 原文地址:https://www.cnblogs.com/FanJava/p/8422646.html
Copyright © 2011-2022 走看看