方法一:利用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的错误会引发莫名其妙的问题。