JavaScript网页表单form中禁止自动提交的两种方式
前言
本文是我本人在开发网页时,在表单中加入了button按钮,本来是用于jQuery点击相应事件的按钮,然后,但我点击button时,发现不是达到jQuery指定效果,原本以为class标签或者其他代码写错,找了很久,之后查找资料,知道表单form提交除了submit提交还有button也会提交,所以总结如何处理不然button 提交表单,在本文中,我们将讨论网页表单(form)中提交的两种方式。
解决方案
return false
一种是在jQuery代码最后加一句:return false,禁止表单提交;
在jQuery事件处理函数中,返回false
可以阻止表单的默认提交行为。这意味着当用户点击按钮时,表单不会执行提交操作。这种方法适用于需要在点击按钮后执行其他操作(如AJAX请求)的情况。
type为button
另一种是定义button标签方式为:新增一个附件即指定type为button
在HTML中,<button>
元素有两种类型:submit
和button
。默认情况下,<button>
元素的类型为submit
,这意味着当用户点击按钮时,表单将执行提交操作。通过将<button>
元素的type
属性设置为button
,我们可以阻止按钮的默认提交行为。这种方法适用于不需要执行表单提交,只需要执行其他操作(如JavaScript事件处理)的情况。
以下是一个表单上传文件并且可以在页面添加多个file的前台页面代码:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>Insert title here</title> </head><script type="text/javascript" src="${pageContext.request.contextPath }/script/jquery-1.7.2.js"></script><script type="text/javascript"> $(function(){ //全局变量 var i=2; //通过表格来进行操作 $("#addFile").click(function(){ alert("www"); $(this).parent().parent().before("<tr class='file'><td>File" + i +":</td><td><input type='file' name='file" + i +"'/></td></tr><tr class='desc'><td>Desc" + i +":</td><td><input type='text' name='desc" + i +"'/><button type='button' id='delete" + i +"'>删除</button></td></tr>"); i++; //获取新添加的删除按钮 $("#delete"+(i-1)).click(function(){ //获取要删除的行即desc var $tr=$(this).parent().parent(); //file行也要删除删除 $tr.prev("tr").remove(); $tr.remove(); //对i重新排序 $(".file").each(function(index){ var n=index+1; $(this).find("td:first").text("File"+n); $(this).find("td: last input").attr("name","file"+n); }); $(".desc").each(function(index){ var n=index+1; $(this).find("td:first").text("Desc"+n); $(this).find("td: last input").attr("name","desc"+n); }); }); //return false,禁止提交表单 return false; }); }); </script> <body> <font color="red">${msg }</font> <br><br> <form action="UploadServlet" method="post" enctype="multipart/form-data"> <input type="hidden" id="fileNum" name="fileNum" value="1"/> <!-- 通过表格包装成一个整体 --> <table> <tr class="file"> <td>File1:</td> <td><input type="file" name="file1"/></td> </tr> <tr class="desc"> <td>Desc1:</td> <td><input type="text" name="desc1"/></td> </tr> <tr> <td><input type="submit" id="submit" value="提交"/></td> <!-- 必须指定类型是type="button"否则,点击后会提交表单 --> <td><button type="button" id="addFile">新增一个附件</button></td> </tr> </table> </form> </body> </html>
总结
- 当需要在点击按钮后执行其他操作(如AJAX请求)时,可以在jQuery事件处理函数中返回
false
以禁止表单提交。 - 当不需要执行表单提交,只需要执行其他操作(如JavaScript事件处理)时,可以将
<button>
元素的type
属性设置为button
以阻止按钮的默认提交行为。
到此这篇关于JavaScript网页表单form中禁止自动提交的两种方式的文章就介绍到这了,更多相关JavaScript form禁止自动提交内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
关于IE浏览器以及Firefox下的javascript冒泡事件的响应层级
原来是由于IE浏览器以及Firefox对于冒泡型事件的支持层次不同造成的。(如对冒泡事件不是很了解可先查询相关资料)2010-10-10bootstrap中selectpicker下拉框使用方法实例
这篇文章主要给大家介绍了关于bootstrap中selectpicker下拉框使用的相关资料,文中通过示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。2018-03-03
最新评论