category_id;?>"/> 使用下面的代码-6ren">
gpt4 book ai didi

javascript - 通过 JQuery AJAX 一起发送 FormData 和字符串数据?

转载 作者:IT王子 更新时间:2023-10-29 00:55:27 29 4
gpt4 key购买 nike

如何使用 FormData() 发布文件和输入字符串数据?例如,我有许多其他隐藏的输入数据,我需要将它们发送到服务器,

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>

使用下面的代码,我只能发送文件数据但不能隐藏的输入数据。

j查询,

// HTML5 form data object.
var fd = new FormData();

var file_data = object.get(0).files[i];
var other_data = $('form').serialize(); // page_id=&category_id=15&method=upload&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);
}
});

服务器.php

print_r($_FILES);
print_r($_POST);

结果,

Array
(
[file] => Array
(
[name] => xxx.doc
[type] => application/msword
[tmp_name] => C:\wamp\tmp\php7C24.tmp
[error] => 0
[size] => 11776
)

)

虽然我想得到这个作为我的结果,

Array
(
[file] => Array
(
[name] => xxx.doc
[type] => application/msword
[tmp_name] => C:\wamp\tmp\php7C24.tmp
[error] => 0
[size] => 11776
)

)

Array
(
[page_id] => 1000
[category_id] => 12
[method] => upload
...
)

这可能吗?

最佳答案

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);
}
});

.each( ) 附加到 FormData

关于javascript - 通过 JQuery AJAX 一起发送 FormData 和字符串数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21060247/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com