如何创建一个同时提交表单和下载 pdf 的按钮?

王林
王林 转载
2023-09-03 11:05:09 519浏览

如何创建一个同时提交表单和下载 pdf 的按钮?

通过使用 HTML、JavaScript 和 jsPDF,我们可以创建一个可以同时提交表单和下载 pdf 的按钮。我们将使用 HTML 创建表单,使用 JavaScript 处理提交过程,并使用 jsPDF 生成 PDF 文档。提交表单和获取 PDF 的行为是最常见的用例之一。在互联网上,PDF 是一种常见的文档格式。它们可用于跟踪合同、发票和其他关键数据。在许多情况下,在收到 PDF 之前需要提交表格。让我们详细讨论一下完整的过程。

开发表单

对于任何在线申请,表格都是必要的组成部分。它们使我们能够收集用户数据并将其传输到服务器。我们将使用 HTML 来构建表单。这是带有五个输入字段的简单表单的示例 -

<form>
   <h2>Tutorials point Contact Form</h2>
   <label for="name">Enter your Name:</label>
   <input type="text" id="name" name="name"><br><br>
   <label for="email">Enter your Email:</label>
   <input type="email" id="email" name="email"><br><br>
   <label for="phone">Enter your Ph.no.:</label>
   <input type="tel" id="phone" name="phone"><br><br>
   <label for="city">Enter your City:</label>
   <input type="text" id="city" name="city"><br><br>
   <label for="state">Enter your current State:</label>
   <input type="text" id="state" name="state"><br><br>
   <button onclick="downloadPDF()">Submit & Download PDF</button>
</form>

我们将使用名为 downloadPDF() 的函数来同时下载并提交表单。

function downloadPDF() { .....CODE HERE …… }
<button onclick="downloadPDF()">Submit & Download PDF/button>

生成 PDF

我们将使用 jsPDF 包来创建 PDF。用于创建 PDF 的 JavaScript 客户端库称为 jsPDF。无需任何服务器端处理,它使我们能够立即生成 PDF。此代码中包含的 JavaScript 方法创建 PDF 文件并将其下载到用户的设备。当用户点击网站上的按钮时,该功能就会被激活。以下是如何使用 jsPDF 创建 PDF 的说明 -

function downloadPDF() { .....CODE HERE …… }
function downloadPDF() {
   var name = document.getElementById("name").value;
   var email = document.getElementById("email").value;
   var phone = document.getElementById("phone").value;
   var city = document.getElementById("city").value;
   var state = document.getElementById("state").value;
   var doc = new jsPDF();
   doc.text(20, 20, "Name: " + name);
   doc.text(20, 30, "Email: " + email);
   doc.text(20, 40, "Phone: " + phone);
   doc.text(20, 50, "City: " + city);
   doc.text(20, 60, "State: " + state);
   doc.save("form.pdf");
} 

集成表单和 PDF 生成

我们现在可以将两者结合起来,因为我们有一个用于创建 PDF 的表单和方法。我们将设计一个按钮,用于同时提交表单并下载 PDF。下面是一个 JavaScript 按钮的示例,它同时提交表单并下载 PDF -

<html>
<head>
   <script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.5.3/jspdf.min.js"></script>
   <style>
      form {
         margin: 20px auto;
         padding: 20px;
         border: 1px solid gray;
         border-radius: 5px;
         width: 500px;
         text-align: center;
      }
      label {
         display: inline-block;
         width: 120px;
         text-align: left;
         margin-right: 10px;
      }
      input[type="text"], 
      input[type="email"],
      input[type="tel"] {
         padding: 10px;
         font-size: 18px;
         border-radius: 5px;
         border: 1px solid gray;
         width: 250px;
         margin-bottom: 20px;
      }
      button {
         margin-top: 20px;
         padding: 10px 20px;
         border-radius: 5px;
         background-color: green;
         color: white;
         font-size: 18px;
         cursor: pointer;
      }
   </style>
   <script>
      function downloadPDF() {
         var name = document.getElementById("name").value;
         var email = document.getElementById("email").value;
         var phone = document.getElementById("phone").value;
         var city = document.getElementById("city").value;
         var state = document.getElementById("state").value;
         var doc = new jsPDF();
         doc.text(20, 20, "Name: " + name);
         doc.text(20, 30, "Email: " + email);
         doc.text(20, 40, "Phone: " + phone);
         doc.text(20, 50, "City: " + city);
         doc.text(20, 60, "State: " + state);
         doc.save("form.pdf");
      }
   </script>
</head>
<body>
   <form>
      <h2>Tutorials point Contact Form</h2>
      <label for="name">Enter your Name:</label>
      <input type="text" id="name" name="name"><br><br>
      <label for="email">Enter your Email:</label>
      <input type="email" id="email" name="email"><br><br>
      <label for="phone">Enter your Ph.no.:</label>
      <input type="tel" id="phone" name="phone"><br><br>
      <label for="city">Enter your City:</label> 
      <input type="text" id="city" name="city"><br><br>
      <label for="state">Enter your current State:</label>
      <input type="text" id="state" name="state"><br><br>
      <button onclick="downloadPDF()">Submit & Download PDF</button>
   </form>
</body>
</html>

在本文中,我们探索了令人兴奋的 Web 开发世界,并了解了如何创建一个按钮,该按钮不仅可以提交表单,还可以使用 JavaScript 一次性下载 PDF。我们逐步完成了使用 HTML 创建表单、使用 JavaScript 处理提交过程以及使用 jsPDF 生成 PDF 文档的步骤。通过结合这些强大的技术,我们成功制作了一个只需单击即可执行这两种功能的按钮。我希望本文内容丰富,让您能够更清楚地了解如何在 JavaScript 的帮助下创建一个同时提交表单和下载 PDF 的按钮。

以上就是如何创建一个同时提交表单和下载 pdf 的按钮?的详细内容,更多请关注php中文网其它相关文章!

声明:本文转载于:tutorialspoint,如有侵犯,请联系admin@php.cn删除