JavaScript Event学习第二章 Event浏览器兼容性


Posted in Javascript onFebruary 07, 2010

在这里提出的事件,当他们发生在一个确定的HTML元素上的时候,他们的名字能够被大多数的浏览器所识别。也就是说,浏览器会查找你为这个HTML元素所注册的事件处理程序的脚本,而且会被立即执行。
      一开始只有为数很少的一些事件。这些事件在几乎所有的JavaScript浏览器都能运行,即使是那些非常古老的。需要注意的是那些早期的事件只能工作在链接或者表单上,有时候也能运行在整个窗口上,但是其他的大多数HTML元素不行。
      时代变迁,很多新的事件也给大家介绍过了。第四代浏览器和更高级的浏览器允许事件注册在任何的HTML元素上。
      所以你基本上可以在任何元素上绑定任何事件,虽然在<P>上绑定一个keydown没有什么意义。
      在这里查看完整的浏览器事件兼容性列表。

界面事件(Interface events)

      界面事件不是被用户动作触发的,而是被用户行为结果触发。
      用户在任何元素上单击都会触发一个click时间。当点击发生在有特殊含义的元素上的时候,额外的界面事件就会被触发。
      例如,当用户在一个链接上单击就触发了click时间。单击这个链接一个新的页面就会被装载,所以这个特殊的click事件导致了界面事件unload的触发。
      其他的界面事件还有resize,scroll和focus/blur。

鼠标事件(mouse events)

      从Netscape 2开始,所有的浏览器都注意到了这样两个事实。当鼠标划入一个链接区域,那么mouseover事件就触发了。当他点击了这个链接那么click事件触发。不久之后mouseout也被添加了进去,他会在鼠标离开链接区域的时候触发。因此传统的鼠标事件三合会(Traditional Triad)成立了。
      第三代的浏览器对于鼠标事件进行了一些扩充。dbclick添加了进来,click事件分割成了mousedown和mouseup:用户按下和弹起鼠标按键。最后跟踪鼠
标轨迹的mousemove也变成了可能
      在后面的章节会详细讲解鼠标事件(mouse event)。

表单事件(Form events)

      表单能够识别submit和reset事件,submit在用户提交表单的时候触发reset在重置表单的时候触发。其中submit事件是所有表单验证代码的核心。当用户提交表单的时候,就遍历一遍表单检查是否有不正确的数据。如果发现了一个错误,停止提交表单并向用户发出一个警告。
      表单还能在某一项得到或者失去焦点的时候识别focus和blur事件,还有键盘事件和click事件。可以查看其他的兼容性列表。
      一般情况下使用这些事件的时候要小心。当用户离开表单中的某一项的时候完全可以用onblur来验证数据,但是通常这都很烦人。用户在忙着填表单的时候不想看见任何弹出来的提示。

W3C事件(W3C events)

      在W3C的DOM 2 事件规范中  还定义了一些突发事件(Mutation events)。这些事件在文档的DOM结构发生变化的时候触发。最常见的一个就是DOMSubtreeModified事件,它会在DOM发生变化的时候触发。
      Mozilla将这个事件设置为subtreemodified。Mozilla也不支持其他的我们没有提到的w3c事件。

微软事件(Microsoft events)

      微软创造了一大堆事件。有一些是非常有趣的。
      当用户在任何时候单击鼠标右键的时候就会触发comtextmenu事件。这非常有用以致滥用。Mozilla也支持这个事件。
      当导入XML文件的时候,readystatechange事件就像一些load事件一样提供服务。当XML文档的readyState变成4的时候,文档就加载完毕了。(不要问我什么是readyState,他管用而且够用)
      让人惊奇的是在unload事件发生之前还有beforeunload事件。他设计的目的是用来取消关闭页面,但是确没人在乎。
      最后微软还发明了mouseenter和mouseleave事件,这两个几乎和mouseover合mouseout事件一样。在鼠标事件一章查看。
      当然以上事件只被IE支持。

Mozilla事件(Mozilla events)

      Mozilla,当然也有一大堆自己的事件。我还没有仔细的研究。

事件处理程序

      所有的事件无论何时触发都会被浏览器检测到。浏览器通常也会执行默认的程序,就像当用户点击一个链接的时候。但是有时候什么也不会发生。

      事件处理程序的重点在于你可以让其他事情发生。你可以在事件发生的时候让浏览器执行你的脚本。如果你这样写了那么无论何时只要事件发生那么你的脚本就会执行。如果这些脚本在符合逻辑的基础上能非常的有用,那么你的用户也会非常的愉快。

      为了确保你的脚本在事件触发的时候能够执行,你需要对HTML元素的确定的动作进行事件注册,就像下面这样:

       <a href="somewhere.html" onClick="alert('I\'ve been clicked!')">

      这样脚本里的alert('I\'ve been clicked!')就会在click事件发生的时候执行。这就注册了一个事件处理程序。

继续

      如果你要继续学习,那么请看下一章。

Javascript 相关文章推荐
CSS+Table图文混排中实现文本自适应图片宽度(超简单+跨所有浏览器)
Feb 14 Javascript
基于jquery的获取mouse坐标插件的实现代码
Apr 01 Javascript
jquery 实现上下滚动效果示例代码
Aug 09 Javascript
js实现动态添加、删除行、onkeyup表格求和示例
Aug 18 Javascript
原生js实现淘宝首页点击按钮缓慢回到顶部效果
Apr 06 Javascript
谈谈JSON对象和字符串之间的相互转换JSON.stringify(obj)和JSON.parse(string)
Oct 01 Javascript
javascript数据类型验证方法
Dec 31 Javascript
实例详解jQuery结合GridView控件的使用方法
Jan 04 Javascript
vue同步父子组件和异步父子组件的生命周期顺序问题
Oct 07 Javascript
微信小程序实现的一键复制功能示例
Apr 24 Javascript
vue实现日历备忘录功能
Sep 24 Javascript
JS实现网页时钟特效
Mar 25 Javascript
JavaScript Event事件学习第一章 Event介绍
Feb 07 #Javascript
jQuery库与其他JS库冲突的解决办法
Feb 07 #Javascript
jQuery学习7 操作JavaScript对象和集合的函数
Feb 07 #Javascript
jQuery 学习6 操纵元素显示效果的函数
Feb 07 #Javascript
jQuery学习5 jQuery事件模型
Feb 07 #Javascript
jQuery学习4 浏览器的事件模型
Feb 07 #Javascript
jQuery学习3:操作元素属性和特性
Feb 07 #Javascript
You might like
「OVERLORD」动画重要删减!雅儿贝德的背叛?至尊猎杀队结成
2020/04/09 日漫
详解PHP防止直接访问.php 文件的实现方法
2017/07/28 PHP
Laravel框架中Blade模板的用法示例
2017/08/30 PHP
PHP执行linux命令6个函数代码实例
2020/11/24 PHP
如果文字过长,则将过长的部分变成省略号显示
2006/06/26 Javascript
javascript学习随笔(使用window和frame)的技巧
2007/03/08 Javascript
jquery Mobile入门—外部链接切换示例代码
2013/01/08 Javascript
使用Grunt.js管理你项目的应用说明
2013/04/24 Javascript
Json字符串转换为JS对象的高效方法实例
2013/05/01 Javascript
javascript ready和load事件的区别示例介绍
2013/08/30 Javascript
禁止选中文字兼容IE、Chrome、FF等
2013/09/04 Javascript
利用javascript实现全部删或清空所选的操作
2014/05/27 Javascript
js关于命名空间的函数实例
2015/02/05 Javascript
javascript拖拽应用实例(二)
2016/03/25 Javascript
Angular2中select用法之设置默认值与事件详解
2017/05/07 Javascript
BootStrap Table前台和后台分页对JSON格式的要求
2017/06/28 Javascript
js 两数组去除重复数值的实例
2017/12/06 Javascript
[56:13]DOTA2-DPC中国联赛定级赛 LBZS vs Phoenix BO3第一场 1月10日
2021/03/11 DOTA
pymssql ntext字段调用问题解决方法
2008/12/17 Python
Python中模块与包有相同名字的处理方法
2017/05/05 Python
Python 中pandas.read_excel详细介绍
2017/06/23 Python
django rest framework 数据的查找、过滤、排序的示例
2018/06/25 Python
Python 获取中文字拼音首个字母的方法
2018/11/28 Python
python列表使用实现名字管理系统
2019/01/30 Python
Python八皇后问题解答过程详解
2019/07/29 Python
Python高级特性 切片 迭代解析
2019/08/23 Python
浅析python中while循环和for循环
2019/11/19 Python
python使用paramiko实现ssh的功能详解
2020/03/06 Python
python两个list[]相加的实现方法
2020/09/23 Python
CSS3媒体查询Media Queries基础学习教程
2016/02/29 HTML / CSS
印尼旅游网站:via
2017/11/12 全球购物
如何使用PHP session
2015/04/21 面试题
四下基层实施方案
2014/03/28 职场文书
没有孩子的离婚协议书怎么写
2014/09/17 职场文书
运动会口号霸气押韵
2015/12/24 职场文书
2019关于垃圾分类处理的调查报告
2019/12/26 职场文书