There is no direct method to download and submit the form simultaneously, but we can perform this task if we control the form submission and on clicking the submit form button we first trigger the downloading of the PDF and then submit the form. So, the approaches which we can follow to achieve this are discussed below:
Approach 1: Creating submit form button outside the form:
- Firstly, create a form with the hidden submit button.
- Give id to the form submit button to access it using JS.
- Create a button outside the form and also give it a unique id to access it.
- Make an anchor tag using createElement property and assigning it the href and download attribute.
- After that, we simply call the submit button click event on clicking the download button, using onClick property.
HTML
| <!DOCTYPE html> <htmllang="en"> <head>     <style>         form {             color: green;         }     </style> </head>    Â<body>     <!-- GFG is the name of the file to be downloaded-->    <!-- In order to run the code, the location of the          file "GFG.pdf" needs to be changed to your local         directory, both the HTML and downloadable file          needs to be present in the same directory -->    <formmethod="post">         <labelfor="username">GFG Username</label>         <inputtype="text"name="username"/>         <inputtype="submit"id="submit-form"            value="submit"hidden />     </form>  Â    <buttonid="download-pdf">Submit</button>  Â    <script>         const downloadPdf = document             .querySelector("#download-pdf");  Â        const submitForm = document             .querySelector("#submit-form");  Â        downloadPdf.addEventListener("click", () => {  Â            // Creating the element anchor that             // will download pdf             let element = document.createElement("a");             element.href = "./GFG.pdf";             element.download = "GFG.pdf";  Â            // Adding the element to body             document.documentElement.appendChild(element);  Â            // Above code is equivalent to             // <ahref="path of file"download="file name">   Â            // onClick property, to trigger download             element.click();  Â            // Removing the element from body             document.documentElement.removeChild(element);  Â             // onClick property, to trigger submit form             submitForm.click();         });     </script> </body>  Â</html> | 
Output:
On Submit:
Approach 2: Disable submission on submit: The more easy method can be disabling the submission on clicking the submit-form button and do submission manually on calling a function that downloads PDF first and then submits the form.
- Firstly, create the form with attribute onsubmit set to ‘return: false;’, which actually prevents the form from submitting on clicking the submit button.
- Make an anchor tag using createElement property and assigning it the href and download attribute.
- After that, we simply call the submit event on the form to submit it, after triggering the download from the element we created.
HTML
| <!DOCTYPE html> <html>  Â<head>     <style>         form {             color: green;         }     </style> </head>  Â<body>     <!-- GFG is the name of the file to be downloaded-->    <!-- In order to run the code, the location of the          file "GFG.pdf" needs to be changed to your local         directory, both the HTML and downloadable file           needs to be present in the same directory -->    <formid="my-form"onsubmit="return: false;">         <labelfor="username">GFG username</label>         <inputtype="text"name="username"/>         <inputtype="submit"id="submit-form"            value="Submit"/>     </form>  Â    <script>         const myForm = document             .querySelector("#my-form");  Â        const submitForm = document             .querySelector("#submit-form");  Â        submitForm.addEventListener("click", () => {  Â            // Creating element to download pdf             var element = document.createElement('a');  Â            // Setting the path to the pdf file             element.href = 'GFG.pdf';  Â            // Name to display as download             element.download = 'GFG.pdf';  Â            // Adding element to the body             document.documentElement.appendChild(element);  Â            // Above code is equivalent to             // <ahref="path to file"download="download name"/>  Â            // Trigger the file download             element.click();  Â            // Remove the element from the body             document.documentElement.remove(element);  Â            // Submit event, to submit the form             myForm.submit();         });     </script> </body>  Â</html> | 
Output:
On Submit:

 
                                    








