你好,游客 登录 注册 搜索
背景:
阅读新闻

网页表单提交方式大全 菜鸟总结 -

[日期:2013-04-04] 来源:  作者: [字体: ]

大家先来看看表单提交的几种方式:

1、<!--通用提交按钮-->
<input type="submit" value="提交">
2、<!--自定义提交按钮-->
<button type="Submit">提交</button>
3、<!--图像按钮-->
<input type="image" src = "btn.png">
说明:用户提交按钮或图像按钮时,就会提交表单。使用<input>或<button>都可以定义提交按钮,只要将其特性的值设置为“submit”即可,而图像按钮则是通过<input>的type特性值设置为”image”来定义的。因此,只要我们单击一下代码生成的按钮,就可以提交表单。

    4、阻止表单提交
只要在表单中存在上面列出的任何一种按钮,那么相应表单控件拥有焦点的情况下,按回车键就可以提交表单。如果表单里没有提交按钮,按回车键不会提交表单。

以这种方式提交表单时,浏览器会在将请求发送给服务器之前触发submit事件。这样,我们就有机会验证表单数据,并据以决定是否允许表单提交。阻止这个事件的默认行为就可以取消表单提交。例如,下面代码会阻止表单提交:

 1 var EventUtil = {
 2     addHandler: function (element, type, handler) {
 3         if (element.addEventListener) {
 4             element.addEventListener(type, handler, false);
 5         } else if (element.attachEvent) {
 6             element.attachEvent("on" + type, handler);
 7         } else {
 8             element["on" + type] = handler;
 9         }
10     },
11     getEvent: function (event) {
12         return event ? event : window.event;
13     },
14     preventDefault: function (event) {
15         if (event.preventDefault) {
16             event.preventDefault();
17         } else {
18             event.returnValue = false;
19         }
20     }
21 
22 };
23 
24 var form = document.getElementById("myForm");
25 EventUtil.addHandler(form, "submit", function () {
26     //取得事件对象
27     event = EventUtil.getEvent(event);
28     //阻止默认事件
29     EventUtil.preventDefault(event);
30 });

调用preventDefault()方法阻止了表单提交。一般来说,在表单数据无效而不能发送给服务器时,可以使用这一技术。

5、在JavaScript中,以编程方式调用submit()方法也可以提交表单。
     这种方式无需表单包含提交按钮,任何时候都可以正常提交表单。来看一个例子:

var form = document.getElementById("myForm");
//提交表单
form.submit();
     在以调用submit()方法的形式提交表单时,不会触发submit事件,因此要记得在调用此方法之前先验证表单数字据。

提交表单时可能出现的最大问题,就是重复提交表单。在第一次提交表单后,如果长时间没有反映,用户可能会变得不耐烦。这时候,他们也许会反复单击提交按钮。结果往往很麻烦(因为服务器要处理重复请求),或者造成错误(如果是下了订单,那么可能会多定好几份)。
解决这一问题的办法有两个:
     在第一次提交表单后就禁用提交按钮;
     利用onsubmit事件处理程序取消后续的表单提交操作。

 

接下来将详细介绍通过form提交的几种方法

方法一:利用form的onsubmit()函数(经常使用),代码如下:

 1 1.<script type="text/javascript">  
 2 2.    function validateForm(){   
 3 3.    if(document.reply.title.value == ""){ //通过form名来获取form   
 4 4.        alert("please input the title!");   
 5 5.        document.reply.title.focus();   
 6 6.        return false;   
 7 7.    }      
 8 8.    if(document.forms[0].cont.value == ""){ //通过forms数组获取form   
 9 9.        alert("please input the content!");   
10 10.        document.reply.cont.focus();   
11 11.        return false;   
12 12.    }   
13 13.    return true;   
14 14.  }   
15 15.<form name="reply"  method="post" onsubmit="return validateForm( );">  
16 16.        <input type="text" name="title"  size="80" /><br />  
17 17.        <textarea name="cont" cols="80" rows="12"></textarea><br />  
18 18.        <input type="submit" value="提交" >  
19 19.</form>  
20 20.注意:   
21 21.1.onsubmit属性内容一定要有return关键字,否则函数会直接执行,不会返回   
22 22.2.validateForm一定要返回一个boolean类型的返回值   
23 23.3.提交按钮要写成submit类型的 

方法二:利用input类型为submit组件的onclick()函数

    1.将上面form标签中的onsubmit="return validateForm()"属性,去掉。

    2.为“提交”按钮添加onclick事件,如下:

     <input type="submit" value="提交" onclick="return validateForm();">

方法三:利用button组件的onclick()函数,手动提交,代码如下:

 1 1.<script type="text/javascript">  
 2 2.    function modifyItem() {   
 3 3.        if (trim(document.getElementById("itemName").value) == "") {   
 4 4.            alert("物料名称不能为空!");   
 5 5.            document.getElementById("itemName").focus();   
 6 6.            return;   
 7 7.        }    
 8 8.        with (document.getElementById("itemForm")) {   
 9 9.            method = "post";   
10 10.            action = "item.do?command=modify&pageNo=${itemForm.pageNo}";   
11 11.            submit();   
12 12.        }   
13 13.    }   
14 14.    //返回   
15 15.    function goBack() {   
16 16.        window.self.location = "item.do?command=list&pageNo=${itemForm.pageNo}";   
17 17.    }   
18 18.</script>  
19 19.<form name="itemForm" id="itemForm">  
20 20.      <input name="itemNo" type="text"   id="itemNo" value="${ item.itemNo }" >  
21 21.      <input name="itemName" type="text"   id="itemName" value="${ item.itemName }" >  
22 22.     <input name="btnModify"  type="button" id="btnModify" value=“修改" onclick="modifyItem()">  
23 23.</form>  
24 24.注意:   
25 25.1.提交时,设置form的action和methods属性,然后利用form.submit()函数提交。

以上代码具体实现可以参考如下:

http://www.bjp111.com/zhshlist.aspx

http://www.bjp111.com/huixiaolist.aspx

http://www.bjp111.com/daililist.aspx

菜鸟小结:

       1.对form中的组件验证时,前两个使用的是name属性,包括form自身的。

       2.如果提交表单时没有反应,同时确定提交表单部分代码没有问题,请查看提交表单前面的js代码,有时前面js的错误会引发莫名其妙的问题。






收藏 推荐 打印 | 录入:admin | 阅读:
相关新闻