首页 > 后端开发 > php教程 > 如何使用 JQuery AJAX 同时发送 FormData 和字符串数据

如何使用 JQuery AJAX 同时发送 FormData 和字符串数据

DDD
发布: 2024-10-22 15:16:02
原创
964 人浏览过

How to Send FormData and String Data Simultaneously Using JQuery AJAX

通过JQuery AJAX同时发送FormData和字符串数据

通过单个AJAX请求即可实现同时传输文件数据和常规输入字符串数据与 FormData() 一起使用。例如,您可能希望将多个隐藏输入字段与文件数据一起包含在服务器请求中。

考虑以下 HTML 表单:

<code class="html"><form action="image.php" method="post" enctype="multipart/form-data">
<input type="file" name="file[]" multiple="" />
<input type="hidden" name="page_id" value="<?php echo $page_id; ?>"/>
<input type="hidden" name="category_id" value="<?php echo $item_category->category_id; ?>"/>
<input type="hidden" name="method" value="upload"/>
<input type="hidden" name="required[category_id]" value="Category ID"/>
</form></code>
登录后复制

使用以下 JQuery 代码但是,只发送文件数据,忽略了隐藏的输入数据:

<code class="jquery">// HTML5 form data object.
var fd = new FormData();

var file_data = object.get(0).files[i];
var other_data = $('form').serialize(); // page_id=&amp;category_id=15&amp;method=upload&amp;required%5Bcategory_id%5D=Category+ID

fd.append("file", file_data);

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

在 FormData() 中同时包含文件和字符串数据的关键在于修改 JQuery 代码,如下所示:

<code class="javascript">var fd = new FormData();
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]);
}
var other_data = $('form').serializeArray();
$.each(other_data,function(key,input){
    fd.append(input.name,input.value);
});
 $.ajax({
    url: 'test.php',
    data: fd,
    contentType: false,
    processData: false,
    type: 'POST',
    success: function(data){
        console.log(data);
    }
});</code>
登录后复制

这些修改引入了一个 for 循环来处理多个文件输入,并将 .serialize() 更改为 .serializeArray() 以获取对象数组以在 .each() 循环中进行操作,其中数据可以是附加到 FormData()。

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

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