首页 > 后端开发 > php教程 > 如何使用 FormData() 和 jQuery AJAX 发送文件和字符串数据?

如何使用 FormData() 和 jQuery AJAX 发送文件和字符串数据?

Mary-Kate Olsen
发布: 2024-10-22 14:39:02
原创
1007 人浏览过

How to Send Both File and String Data with FormData() and jQuery AJAX?

使用 FormData() 和 jQuery AJAX 发布文件和字符串数据

通常需要通过以下方式发送文件和输入字符串数据AJAX 请求。要使用 FormData() 实现此目的,请按照以下步骤操作:

  1. 创建 FormData 对象:

    <code class="js">var fd = new FormData();</code>
    登录后复制
  2. 附加文件数据:
    a.对于单个文件:

    <code class="js">fd.append("file", file_data);</code>
    登录后复制

    b.对于多个文件:

    <code class="js">var file_data = $('input[type="file"]')[0].files; // for multiple files
    for(var i = 0;i<file_data.length;i++){
        fd.append("file_"+i, file_data[i]);
    }</code>
    登录后复制
  3. 附加字符串数据:

    <code class="js">var other_data = $('form').serializeArray();
    $.each(other_data,function(key,input){
        fd.append(input.name,input.value);
    });</code>
    登录后复制
  4. 发送数据AJAX:

    <code class="js">$.ajax({
        url: 'url',
        data: fd,
        contentType: false,
        processData: false,
        type: 'POST',
        success: function(data){
            alert(data);
        }
    });</code>
    登录后复制

按照以下步骤,您可以在同一 FormData 对象和 AJAX 请求中发送文件和输入字符串数据。

以上是如何使用 FormData() 和 jQuery AJAX 发送文件和字符串数据?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板