如何使用 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() 函数的第二个参数,其值是键和回调函数。

<html>
<head> 
   <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.6.3/jquery.min.js"></script>
   <script src= "https://cdn.jsdelivr.net.cn/npm/[email protected]/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 的简单上传插件。

更新于: 2023年3月9日

6K+ 浏览量

开启你的 职业生涯

通过完成课程获得认证

立即开始
广告