JS表单提交的方法有以下几种常见的方式:使用form元素的submit()方法、使用AJAX进行异步提交以及使用fetch API进行异步提交。
代码示例:
<form id="myForm" action="submit.php" method="POST"> <input type="text" name="username" /> <input type="password" name="password" /> <input type="submit" value="提交" /> </form> <script> const form = document.querySelector('#myForm'); form.addEventListener('submit', (e) => { e.preventDefault(); // 阻止表单的默认提交行为 // 进行表单验证 // ... // 提交表单 form.submit(); }); </script>
代码示例-使用原生的XMLHttpRequest:
<form id="myForm" action="submit.php" method="POST"> <input type="text" name="username" /> <input type="password" name="password" /> <input type="submit" value="提交" /> </form> <script> const form = document.querySelector('#myForm'); form.addEventListener('submit', (e) => { e.preventDefault(); // 阻止表单的默认提交行为 // 进行表单验证 // ... // 构造请求对象 const xhr = new XMLHttpRequest(); xhr.open('POST', 'submit.php', true); // 设置请求头 xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); // 监听请求状态 xhr.onreadystatechange = function() { if (xhr.readyState === XMLHttpRequest.DONE && xhr.status === 200) { console.log(xhr.responseText); } }; // 发送请求 xhr.send(new FormData(form)); }); </script>
代码示例:
<form id="myForm" action="submit.php" method="POST"> <input type="text" name="username" /> <input type="password" name="password" /> <input type="submit" value="提交" /> </form> <script> const form = document.querySelector('#myForm'); form.addEventListener('submit', (e) => { e.preventDefault(); // 阻止表单的默认提交行为 // 进行表单验证 // ... // 构造请求参数对象 const formData = new FormData(form); // 发起fetch请求 fetch('submit.php', { method: 'POST', body: formData }) .then(response => response.text()) .then(data => console.log(data)) .catch(error => console.log(error)); }); </script>
以上是JS中常见的表单提交方法,可以根据实际需要选择适合的方法进行表单提交。