button的type属性

  今天由于项目需求,需要js控制form的提交,在submit前先进行数据的验证和处理。

  

  html的代码如下:  

1 <div class="test-ft">
2     <h3 class="shouji">手机号码凶吉</h3>
3     <form needcheck="1" method="post" target="_blank" action="http://www.go108.com.cn/go108_mobile_free_sz.php">
4         <p>
5                     ...
6             </p>
7         <button class="btn-act">马上测</button>
8     </form>
9 </div>                                    

  编码完成后,在做浏览器的兼容性测试是出现了问题:ie6、ie7下点击按钮没反映,跳转不到指定url,其他浏览器却可以正常跳转

  一直以为是js控制代码中出现了问题,所以跟踪调试很久,始终没发现问题。后来,发现button没有指定type为submit,所以怀疑是不是这个问题。

  修改添加button的type属性为submit后,ie6、ie7下功能正常。

  过去一直没有注意过这样的问题,踩了坑,所以去搜索资料查询验证。

  w3shool上有对button的type属性做详细说明: 

  http://www.w3school.com.cn/tags/att_button_type.asp 

定义和用法
type 属性规定按钮的类型。
提示:请始终为按钮规定 type 属性。Internet Explorer 的默认类型是 "button",而其他浏览器中(包括 W3C 规范)的默认值是 "submit"

可以看出,其他浏览器下默认button点击后会提交form,而ie默认点击后是不提交form的,type的默认值也是个浏览器兼容性问题,所以mark下。

posted on 2012-10-30 20:13  GRisGR  阅读(1843)  评论(0编辑  收藏  举报

导航