缺省type属性值

<button>提交</button>

button元素的type属性值有submit、button可选,在上面这种没有明确指出type值的情况下,浏览器的缺省值不一样;

IE6、IE7、IE8兼容模式缺省是 type="button",其它浏览器缺省是 type="submit" ,要验证这点可以把它放到form表单元素中,点击按钮看是否做了提交操作;演示DEMO


click事件劫持

在IE6、IE7、IE8中当button元素 type="submit" 时,在button元素上绑定click事件,然后当焦点不在这个button元素上时按回车键,这时候会触发button元素的点击事件,我管这个行为叫click事件劫持;

经过仔细探究发现,它只会触发非form表单中的第一个button元素的click事件,详细的可以看演示DEMO


我遇到过的问题

现在回头来看遇到的问题,在项目中我有一个button元素 <button>提交</button> 绑定了click事件,在IE8标准模式下,在页面上任何地方回车都会触发这个 button 元素的click事件,由上面的分析可以看出来,原因在于IE8标准模式下button元素缺省 type="submit" ,这就导致触发click事件劫持,详细的可以看演示DEMO


总结

要回避这个兼容问题,只要记得每次用button元素的时候都添加上合适的type就可以,这也是个编码好习惯;

文章来源:http://www.gafish.net/archives/1549

最新文章

  1. WebService开发
  2. 用户输入函数--raw_input、input
  3. Scrapy入门教程
  4. 转:Redis Geo: Redis新增位置查询功能
  5. UVaLive6039 Uva1668 Let&#39;s Go Green
  6. Spark GraphX的函数源码分析及应用实例
  7. 【iOS与EV3混合机器人编程一系列五个】iOS_WiFi_EV3_Library 解剖连接EV3
  8. swift笔记 (三) —— 字符和字符串
  9. 【剑指offer】二叉搜索树转双向链表
  10. iOS之内存分析
  11. python自动化测试应用-第6篇(WEB测试)--Selenium元素篇
  12. 删除oracle数据库[转]
  13. 认识Zygote
  14. T-SQL :SQL Server 定义数据完整性 6大约束(三)
  15. windows 获取用户的Sid的方法
  16. [离散时间信号处理学习笔记] 3. 一些基本的LTI系统
  17. docker安装问题:E: Package &#39;docker-ce&#39; has no installation candidate
  18. 深度学习框架caffe/CNTK/Tensorflow/Theano/Torch的对比
  19. EZ 2018 05 20 NOIP2018 模拟赛(十五)
  20. springboot环境下配置过滤器和拦截器

热门文章

  1. 认识什么是SEO
  2. Jquery 概念性内容编辑器
  3. Hdu3498-whosyourdaddy(精确覆盖模板题)
  4. PHP文件目录copy
  5. 基础总结篇之四:Service完全解析
  6. [Regular Expressions] Find a String that Precedes Another String ?= , ?!
  7. Android应用程序启动过程源代码分析
  8. Java内存区域和GC机制篇
  9. css基本选择器
  10. HTML入门基础