方法一:利用form的onsubmit()函数
<script type="text/javascript"> function validateForm(){ if(document.reply.title.value==""){//通过form名来获取form alert("please input the title!"); document.reply.title.focus((); return false; } if(document.forms[0].cont.value==""){//通过forms数组获取form alert("please input the content!"); document.reply.cont.focus(); return false; } return true; } <form name="reply" method="post" onsubmit="return validateForm();"> <input type="text" name="title" size="80"/><br/> <textarea name="cont" cols="80" rows="12"></textarea><br/> <input type="submit" value="提交"> </form>
注意:
1、onsubmit属性内容一定要有return关键字,否则函数会直接执行,不会返回
2、validateForm一定要返回一个boolean类型的返回值
3、提交按钮要写成submit类型的
方法二:利用input类型为submit组件的onclick()函数
1、将上面form标签中的onsubmit=“return validateForm()”属性,去掉
2、为“提交”按钮添加onclick事件,如下:
<input type="submit" value="提交" onclick="return validateForm();">
方法三:利用button组件的onclick()函数,手动提交
<script type="text/javascript"> function modifyItem(){ if(trim(document.getElementById("itemName").value)==""){ alert("物料名称不能为空!"); document.getElementById("itemName").focus(); return; } with(document.getElementById("itemForm")){ method="post"; action="item.do?command=modify&pageNo=${itemForm.pageNo}"; submit(); } } //返回 function goBack(){ window.self.location="item.do?command=list&pageNo=${itemForm.pageNo}"; } </script> <form name="itemForm" id="itemForm"> <input name="itemNo" type="text" id="itemNo" value="${item.itemNo}"> <input name="itemName" type="text" id="itemName" value="${item.itemName}"> <input name="btnModify" type="button" id="btnModify" value="修改" onclick="modifyItem()"> </form>
注意:
1、提交时,设置form的action和methods属性,然后利用form.submit()函数提交
总结:1、对form中的组件验证时,前两个使用的是name属性,包括form自身的
2、如果提交表单时没有反应,同时确定提交表单部分代码没有问题,请查看提交表单前面的js代码,有时前面js的错误会引发莫名其妙的问题
时间: 2024-11-09 00:49:40