JavaScript 如何在没有表单的情况下上传文件
有时,开发人员可能需要在JavaScript中不使用表单来上传文件。通常,我们会创建一个表单来获取用户的数据和文件,但在本教程中,我们将学习如何在没有表单的情况下从用户处获取文件并将其发送至后端。
使用FormData()对象和Ajax请求
FormData对象允许我们将表单数据存储在键值对中。我们需要使用构造函数来初始化变量。我们可以允许用户使用HTML输入上传文件并将该文件存储在表单数据中。随后,我们可以将表单数据发送至后端。
语法
用户可以按照下面的语法使用FormData()对象和ajax请求来在没有使用表单的情况下上传文件。
form_data.append("file", uploadedFile);
$.ajax({
url: "URL",
method: "POST",
data: form_data,
});
在上面的语法中,我们使用append()方法将文件添加到表单数据对象中。同时,我们使用ajax()将数据发送到API。
示例
在下面的示例中,我们使用<input>
标签在HTML中创建文件输入。在JavaScript中,当用户上传文件时,我们获取文件并将其添加到form_data对象中。
之后,我们使用ajax通过POST请求将文件发送到API。
<html>
<head>
<script src = "https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.3/jquery.min.js"></script>
</head>
<body>
<h3>Using the <i>FormData object and ajax request</i> to upload a file without using the form data in JavaScript</h3>
<input type = "file" name = "file" id = "file_input" />
<div id = "content"> </div>
<script>
(document).on('change', '#file_input', function () {
let uploadedFile = document.getElementById('file_input').files[0];
var form_data = new FormData();
form_data.append("file", uploadedFile);.ajax({
url: "URL",
method: "POST",
data: form_data,
});
});
</script>
</body>
</html>
使用jQuery简单上传插件
jQuery包含了简单上传插件,我们可以用它来发送文件到API。我们需要将简单上传插件的CDN添加到<head>
部分中以便使用。如果开发者正在使用该应用程序,他们可以使用NPM命令来安装该包。
语法
用户应按照下面的语法使用jQuery简单上传插件,在JavaScript中上传文件而不使用表单。
$(this).simpleUpload("URL", {
start: function (file) {
//upload started
},
});
在上述语法中,我们调用了简单上传插件的simpleUpload()函数来上传文件。
示例
在下面的例子中,我们在<head>
部分中添加了simpleUpload.min.js文件的路径。我们在文件输入端添加了change
事件。在回调函数中,我们通过将文件输入作为引用来调用simpleUpload()函数。我们将对象作为第二个参数传递给simpleUpload()函数,并将key和回调函数作为值。
<html>
<head>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.3/jquery.min.js"></script>
<script src= "https://cdn.jsdelivr.net/npm/jquery-simpleupload@1.1.0/simpleUpload.min.js"> </script>
</head>
<body>
<h3>Using the <i>jQuery simple upload</i> plugin to upload the file without using the form</h3>
<input type = "file" name = "file" id = "file_input">
<div id = "content"> </div>
<script>
('#file_input').change(function () {(this).simpleUpload("abcd.php", {
start: function (file) {
//upload started
content.innerHTML = "upload started";
},
});
});
</script>
</body>
</html>
用户学习了两种不使用JavaScript表单上传文件的方法。在第一种方法中,我们使用了FormData对象和ajax()方法。在第二种方法中,我们使用了Jquery的简单上传插件。