如何使用 JavaScript 上传文件而不使用表单?

javascriptweb developmentfront end technology

有时,开发人员可能需要在 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/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 的简单上传插件。


相关文章