gpt4 book ai didi

javascript - 如何使用 ajax 上传文本字段和文件?

转载 作者:行者123 更新时间:2023-11-28 01:58:43 25 4
gpt4 key购买 nike

我是 AJAX 的新手,正在研究一种表单的实现,该表单会将名称和文件上传到 php 文件,该文件处理数据并将其发送到数据库以使用 mysqli 进行插入。我已经测试了 php 文件,它确实有效。我的问题出在 AJAX 代码中。我试过使用 XMLHTTP 和 jQuery 的实现。两者都离开页面并在浏览器中打开 PHP 文件。作为免责声明,我将这个问题发布到另一个编码站点,随后两个发帖人之间发生了争执,因此我在这里尝试希望通过富有成效的建议得到理性和冷静的回应。

我意识到目前“get”被发送到 PHP 文件而不是“post”,但是 PHPStorm 告诉我“post”在那种形式下不可用。我有什么选择?我走在正确的轨道上还是我应该走的另一个方向?如何只刷新表单并阻止 PHP 页面加载?

这是我的代码的相关片段,

<!DOCTYPE html>
<html>
<head>
<script src="jquery.min.js"></script>
<script src="jquery.validate.js"></script>
<script>
$(document).ready(function() {
$('#addForm').validate({

submitHandler: function (form) {
$('input[name="usingAJAX"]', this).val('true');
var url = $(form).prop('action');
var dataToSend = $(form).serialize();
var callback = function(dataReceived) {
$(form).hide();
//result message
$('body').append(dataReceived)
};
var typeOfDataToReceive = 'html';

$.get(url, dataToSend, callback, typeOfDataToReceive),
return false;
}
});
});

</script>
</head>
<body>
<form id="addForm" action="addInfo.php" enctype="multipart/form-data">
<input type="hidden" name="usingAJAX" value="false"/>
<label for="aname">Name: </label>
<input type="text" name="aname" id="aname" class=required/>
<label for="aimage">Photo: </label>
<input id="aimage" type="file" name="aimage" class="required">
<input type="submit" value="ADD"/>
</form>
</body>
</html>

最佳答案

直到最近,您还无法使用 ajax 上传文件。

您仍然无法使用 ajax 直接上传文件,但您可以使用 HTML5 文件 API 以编程方式完成。

不过,如果您正在寻找简单的解决方案,请尝试传统的 IFrame 方法。

如果您想要前沿技术,请使用文件 API。这是一些tutorial如何使用 javascript 读取文件。

ajax上传步骤:

  1. 使用 javascript FileReader API 读取文件。
  2. 将编码为 base64 或其他格式的文件内容发布到服务器。
  3. 服务器端,以编程方式解码文件内容。

当使用这种方法时,服务器不会将文件作为文件上传处理。这将只是另一个带有文本的请求字段。您可以在服务器端对其进行解码。

filereader API 允许您逐份读取文件并上传文件片段,因此可以分块上传大文件,但您需要自己处理。

关于javascript - 如何使用 ajax 上传文本字段和文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15362383/

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