我正在尝试通过Ajax将数据(输入文本,下拉列表等)和文件发送到PHP文件。我使用此函数添加名为 Action 的额外参数。动作可以是其中一些文本:“添加”,“编辑”,“读取”和“删除”(压缩选项)。参见下面的脚本:
function recordActions(action_name, id) {
//id = (typeof id == "undefined") ? '' : id;
var frm = document.getElementById(action_name + '_form');
var form_data = new FormData();
form_data.append('action', action_name);
form_data.append('fd', frm);
$.ajax({
type: 'post',
dataType: 'json',
url: '<?php echo FILENAME_USERS_ACTIONS; ?>',
data: form_data,
cache: false,
processData: false,
contentType: false,
success:
if (data.action == 'add' || data.action == 'edit') {
$("#" + action_name + '_form')[0].reset();
$("#" + action_name + '_div').slideUp();
}
showWeekAgenda();
}
});
// esta línea evita que la página se refresque dando a Cancelar la visita y evita que salga Error en Success de Arriba
if (action_name == 'cancel') return false;
}
当Ajax调用PHP文件()时,我不知道如何访问FormData中包含的数据。 在Web Developer中看到了Params,我明白了:
-----------------------------81668061412059330971865480216
Content-Disposition: form-data; name="action"
actadd
-----------------------------81668061412059330971865480216
Content-Disposition: form-data; name="fd"
[object HTMLFormElement]
-----------------------------81668061412059330971865480216--
然后,我在PHP中放入一些代码来查看参数及其值:
print_r($_POST);
print_r($_FILES);
echo '<br>Post: ' . $_POST['fd'];
但我无能为力。
Array
(
[action] => actadd
[fd] => [object HTMLFormElement]
)
Array
(
)
<br>Post: [object HTMLFormElement]
任何人都知道如何访问 fd 内的任何值吗? fd应该具有我的输入文本,下拉菜单,文本区域等的值。
按照以下问题的答案:Uploading both data and files in one form using Ajax?,我们可以将所有HTML控件放入一个FormData中。
预先感谢!
答案 0 :(得分:0)
创建FormData
对象时,应将表单传递给构造函数,以使用表单值填充它。然后,您可以将action
值附加到该结果:
var frm = document.getElementById(action_name + '_form');
var form_data = new FormData(frm);
form_data.append('action', action_name);
以这种方式进行操作时,应该会在PHP代码中正确填充$_POST
和$_FILES
。