网页表单提交方式详细汇总

当前位置 : 首页 > 网页制作 > 心得技巧 > 网页表单提交方式详细汇总

网页表单提交方式详细汇总

来源:互联网 作者:脚本宝典 时间:2015-09-04 13:28
大家先来看看表单提交的几种方式 : 1、!--通用提交按钮-- input type=submit value=提交 2、!--自定义提交按钮-- button type=Submit提交/button 3、!--图像按钮-- input type=image src = btn.png 说明:用户提

大家先来看看表单提交的几种方式: 
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事件。这样,我们就有机会验证表单数据,并据以决定是否允许表单提交。阻止这个事件的默认行为就可以取消表单提交。例如,下面代码会阻止表单提交: 

复制代码

代码如下:


var EventUtil = { 
addHandler: function (element, type, handler) { 
if (element.addEventListener) { 
element.addEventListener(type, handler, false); 
} else if (element.attachEvent) { 
element.attachEvent("on" + type, handler); 
} else { 
element["on" + type] = handler; 

}, 
getEvent: function (event) { 
return event ? event : window.event; 
}, 
preventDefault: function (event) { 
if (event.preventDefault) { 
event.preventDefault(); 
} else { 
event.returnValue = false; 


}; 
var form = document.getElementById("myForm"); 
EventUtil.addHandler(form, "submit", function () { 
//取得事件对象 
event = EventUtil.getEvent(event); 
//阻止默认事件 
EventUtil.preventDefault(event); 
}); 


调用preventDefault()方法阻止了表单提交。一般来说,在表单数据无效而不能发送给服务器时,可以使用这一技术。 
5、在JavaScript中,以编程方式调用submit()方法也可以提交表单。 
这种方式无需表单包含提交按钮,任何时候都可以正常提交表单。来看一个例子: 
var form = document.getElementById("myForm"); 
//提交表单 
form.submit(); 
在以调用submit()方法的形式提交表单时,不会触发submit事件,因此要记得在调用此方法之前先验证表单数字据。 
提交表单时可能出现的最大问题,就是重复提交表单。在第一次提交表单后,如果长时间没有反映,用户可能会变得不耐烦。这时候,他们也许会反复单击提交按钮。结果往往很麻烦(因为服务器要处理重复请求),或者造成错误(如果是下了订单,那么可能会多定好几份)。 
解决这一问题的办法有两个: 
在第一次提交表单后就禁用提交按钮; 
利用onsubmit事件处理程序取消后续的表单提交操作。 
接下来将详细介绍通过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" />

<textarea name="cont" cols="80" rows="12"></textarea>

<input type="submit" value="提交" > 
</form> 
注意: 
1.onsubmit属性内容一定要有return关键字,否则函数会直接执行,不会返回 
2.validateForm一定要返回一个boolean类型的返回值 
3.提交按钮要写成submit类型的 


方法二:利用input类型为submit组件的onclick()函数 
将上面form标签中的onsubmit="return validateForm()"属性,去掉。 
为“提交”按钮添加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()函数提交。 


以上代码具体实现可以参考如下: 
http://www.bjp111.com/zhshlist.aspx 
http://www.bjp111.com/huixiaolist.aspx 
http://www.bjp111.com/daililist.aspx 
菜鸟小结: 
对form中的组件验证时,前两个使用的是name属性,包括form自身的。 
如果提交表单时没有反应,同时确定提交表单部分代码没有问题,请查看提交表单前面的js代码,有时前面js的错误会引发莫名其妙的问题。


Tag:
网友评论

<