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) {  
         }
       });
    }
  • 相关阅读:
    机器学习&数据挖掘笔记_16(常见面试之机器学习算法思想简单梳理)
    linux_shell_根据网站来源分桶
    mac_Alfred_快捷设置
    linux_无密登录
    crawler_Docker_解决用 JavaScript 框架开发的 Web 站点抓取
    linux下查看最消耗CPU、内存的进程
    绕过登陆常用万能密码
    ctf比赛linux文件监控和恢复shell
    Python爬虫之Selenium的常用方法
    CTF比赛时准备的一些shell命令
  • 原文地址:https://www.cnblogs.com/FanJava/p/8422646.html
Copyright © 2011-2022 走看看