今天遇到一个js 的bug 如下图所示:
一般form表单重置
js的方式是:document.getElementById(“form”).reset()。
jquery的方式是:则使用 $("#form")[0].reset() 或者 $("#form").trigger(“reset”) 。
页面具体内容如下:
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>My JSP 'login.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<script src="<%=basePath%>/js/jquery-1.8.3.min.js" type="text/javascript" ></script>
<script type="text/javascript">
$(function(){
$("#reset").click(function(){
$("#form")[0].reset();
});
})
</script>
</head>
<body>
<form action="" id="form">
登录名称:<input type="text" name="name" ><br>
登录密码:<input type="password" /><br>
<input type="button" value="登录">
<input type="button" id="reset" value="重置">
</form>
</body>
</html>
最终发现原因是将重置按钮的id属性名称设置成啦 reset 这样会覆盖原来的reset方法。 也就是说 id=“reset” 和 name=“reset” 这2中方式都不行。
我们将其改成id=“resetButton” 就ok了。