form提交的几种方法

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

posted @ 2015-05-21 10:41  北倍  阅读(610)  评论(0编辑  收藏  举报