DOM规范没有涵盖所有浏览器支持的所有事件

而许多浏览器出于满足用户需求,或解决特殊问题的目的,实现了一些自定义事件

HTML5列出了浏览器应该支持的所有事件,这里只讨论得到浏览器完善支持的事件(并非全部)

contextmenu事件

windows95 在PC中引入了上下文菜单的概念,即通过鼠标右键可以调出上下文菜单

在该概念提出后不久,该概念也被引入了web 领域

在web中实现该概念,开发人员面临的主要问题是:1.如何确定上下文菜单以何种方式打开(windows中鼠标右键,Mac中 ctrl + 单击) 2.如何屏蔽默认的上下文菜单的行为

为解决以上问题,出现了 contextmenu 这一事件,该事件触发时表示正在访问上下文菜单

通过这一事件,开发人员可以方便地提供自定义菜单

由于该事件是冒泡的,所以我们只需要为 document 提供事件处理程序,就可以将默认的菜单行为替代为我们自定义的菜单

需要注意的是该事件属于鼠标事件,所以在其事件对象上会提供光标位置有关的属性

通过这一属性我们就可以将我们的自定义菜单放到用户触发该事件时的位置,也就像我们平常使用的时候那样菜单出现在我们光标的位置

不过在使用时我们还需要阻止浏览器的默认菜单行为

在兼容DOM的浏览器中,我们可以使用 event.preventDefalut() 方法来取消浏览器的默认菜单行为

在不兼容DOM的浏览器中(如 IE低版本) 则需要将 event.returnValue 设置为false 来阻止默认行为

如下代码所示:

<ul style = "position:absolute;visibility:hidden;background-color:sliver" id="menu">
<li><a href="www.baidu.com">百度</a><li>
<li><a href="www.google.com">谷歌</a><li>
<ul>

上方代码在文档中创建了一个隐藏的菜单,该菜单由两个网址连接组成

这样我们就准备好了自定义菜单,下面我们则需要把浏览器默认的上下文菜单替换为我们的自定义菜单

window.onload = function(event){//当文档加载完成我们就需要替换掉默认的菜单
var menu = document.getElementById("menu"); document.addEventLinsener("contentmenu",function(events){
events.preventDefault();//阻止默认行为
menu.style.left = events.clientX + "px";
menu.sytle.top = event.clientY + "px";
menu.style.visibility = "visible"
},false); document.onlick = function(){
menu.style.visibility = "hidden";
}// 点击页面隐藏菜单
}

需要注意的是,我上方的示例没有做兼容处理,如需要跨浏览器使用则需要对事件绑定,以及事件对象进行兼容

可以参考 这篇文章,而支持该事件的浏览器有: IE Chrome Firefox Safari Opera 11+

beforeunload事件

beforeunload事件用于让开发人员能够在浏览器卸载页面之前,阻止这一行为

这一事件主要用于,弹出一个询问是否离开当前页面的弹窗,通过这一事件将控制权交给用户,防止因用户的误操作带来的不便

那么如何在浏览器中实现呢?

如下方代码所示:

window.addEventListener("beforeunload",function(event){
   event.preventDefault();  
event.returnValue = '';//chrome浏览器需要设置
},false);

处于安全性的考虑,现代的主流浏览器并不支持由我们来提供用户的提示信息

也就是我们没有必要设置 returnValue,但是chrome 浏览器需要设置以下该值(什么值都行只要不是undefined)才能正常工作

DOMContentLoaded事件

我们知道,window的load事件会在页面中的所有内容加载完毕后触发

但是往往我们在DOM结构建立完成的时候就需要对页面内容进行操作了,如果加载css等资源的时间过长,那么用户如果在这加载期间进行操作,就会给人没有响应的感受,脾气不好的用户很可能就会关掉网页,这当然不是我们想要看到的

对于这样的一种需求,DOMContetLoaded 事件应运而生

该事件在当前文档形成完整的DOM树之后就会触发

通过该事件我们可以让用户更早地和页面进行交互

要处理这一事件我们可以对 Document、window 绑定事件处理程序

虽然该事件会冒泡到window,但是该事件的目标是document

而这一事件的 event 事件对象并不会提供额外的信息

而对于不支持该事件的浏览器我们可以使用以下代码来代替:

setTimeout(function(){
//在此添加事件处理程序
},0);

需要注意的是,这样的写法并不一定代表这样添加的事件处理程序一定会早于load事件触发

readystatechange事件

IE为DOM中的某些部分提供,readystatechange 事件

该事件用于提供文档或元素加载状态的有关信息

该事件的事件对象有一个readyState 属性

该属性的值为下面五个值中的一个:

  1. uninitialized:尚未初始化
  2. loading:正在加载数据
  3. loaded:对象加载数据完成
  4. interactive:可以操作,尚未完全加载
  5. complete:对象已经加载完毕

需要注意的是并非所有的对象都会经历以上的五个状态,通常情况下该事件触发次数会少于四次

对于document而言,值为“interactive”的阶段与 DOMContentLoaded 事件的阶段大致相同

该事件与DOMContentLoaded 事件最大的区别在于,无法判断该事件与 load 事件的先后顺序

也就是这一事件并不一定会早于load事件触发

所以如果希望页面尽早开始交互可以使用以下代码:

document.attachEvent("onreadystatechange",function(event){
if(document.readyState =="intertactive" || document.readyState =="complete"){
document.detachEvent("onreadystatechange",arguments.callee,false);//解除事件处理程序
//需要进行的页面操作
}
},false)

支持readystatechange事件的浏览器有 IE、firefox、Opera,上方的例子以IE为例

需要注意的是:上方的代码可以近似地模拟DOMContentLoaded事件,但是其本质上仍是不同的,在不同的页面中load事件与readystatechange事件并不能保证以相同的顺序触发

pageshow与pagehide事件

在Firefox与Opera浏览器中有一个特性,叫“往返缓存”,用于当用户使用“前进”、“后退”按钮时加快页面的转换速度

本质上该特性相当于将当前整个页面存在内存中,所以当我们在上述浏览器使用前进、后退时并不会触发load事件

为此Firefox提供了一些新的事件

其中  pageshow 事件会在页面显示时触发,无论页面是否来自“往返缓存”

该事件会在load事件之后触发

虽然该事件的目标是document 但是必须将该事件的事件处理程序添加到 window 才能正常生效

该事件的事件对象有一个 persisted 的布尔值属性,如果页面来自 “往返缓存”则为 true 否则为 false

与pageshow 对应的是pagehide,该事件会在页面卸载时触发(早于unload事件)

对于这两个事件,只有IE9以下和Safari5以下的浏览器不支持

hashchange事件

hashchange事件应该说是这些事件中用途最广的了

前些时候,当前后分离是主流的web应用的开发模式的时候,hashchange事件可以说是功不可没

url中的hash值可以用来在不同页面之间传递信息,也就是前端路由的一种实现方式

现如今更多的时候 hashchange事件用于单页应用

我们知道单页应用只有一个HTML页面,通过这一个页面来实现许多复杂的功能

通过 hashchange 事件我们可以将单页应和多页应用的表现一致化

话说回来,该事件会在页面的 url 中的 # 后面的部分(hash值)发生变化时触发

该事件的event 对象包含两个额外的属性:

  • oldURL:变化前的url
  • newURL:变化后的url

虽然大多数浏览器实现了 hashchange事件

但是其中只有一部分支持,上面的额外属性,所以最好使用loaction 对象来获取当前的 url的参数列表(location.hash)

Javascript高级编程学习笔记(67)—— 事件(11)HTML5事件的更多相关文章

  1. Javascript高级编程学习笔记(71)—— 模拟事件(1)DOM事件模拟

    事件,指的是网页中某个特定的交互时刻 一般来说事件由浏览器厂商负责提供,一般由用户操作或者其它浏览器功能来触发 但是有一类特殊的事件,那就是由我们开发人员通过JS触发的事件 这些事件和浏览器创建的事件 ...

  2. Javascript高级编程学习笔记(72)—— 模拟事件(2)IE事件模拟

    IE中的事件模拟 低版本的IE浏览器作为前端开发的一股清流,想避过都不行 虽然低版本IE正在逐步被市场淘汰,不得不承认IE8以下的浏览器依然占了不小的份额 所以这里大概介绍IE8以下的低版本IE中的事 ...

  3. Javascript高级编程学习笔记(48)—— HTML5

    HTML变动最大的版本应该就是HTML5了,这里就介绍一些 HTML5新增的DOM相关的API 与类相关的扩充 HTML4在普及后有一个十分重要的变化,即class属性使用的场景越来越多 所以HTML ...

  4. Javascript高级编程学习笔记(57)—— 事件(1)事件流

    事件 JS与HTML的交互是通过事件实现的 而事件指的就是:文档或浏览器窗口特定的交互瞬间 可以通过侦听器来预定事件,以便在事件发生时执行相应的代码 这种模式也是设计模式中的观察者模式 事件流 有了事 ...

  5. Javascript高级编程学习笔记(70)—— 事件(14)内存和性能

    由于事件处理程序是现代的web程序交互能力的提供者 所以在日常实践中,我们免不了要向页面中添加大量的事件处理程序(不管是用于用户交互还是用于统计用户数据) 在创建GUI(图形用户界面)的语言(如C#) ...

  6. Javascript高级编程学习笔记(69)—— 事件(13)触摸与手势事件

    触摸与手势事件 由于移动设备既没有鼠标也没有键盘,所以在为移动浏览器开发交互性网页时,常规的鼠标键盘事件根本不够用 所以早期的苹果为Safari 添加了一些与触摸相关的事件 随着后面Android的W ...

  7. Javascript高级编程学习笔记(68)—— 事件(12)设备事件

    设备事件 随着智能手机与平板电脑的普及,为了更好地让用户与这些设备进行交互 浏览器引入了一种新的方式,而一类新的事件也应运而生,这就是设备事件 W3C从2011年开始制定关于设备事件的草案 下面将会介 ...

  8. Javascript高级编程学习笔记(66)—— 事件(10)变动事件

    变动事件 DOM2级的变动事件,能在DOM中的一部分发生变化时给出提示 变动事件是为XML或HTML DOM 设计的,并不特定于某种语言 DOM2级定义了如下变动事件: DOMSubtreeModif ...

  9. Javascript高级编程学习笔记(64)—— 事件(8)键盘与文本事件

    键盘与文本事件 用户在使用键盘时会触发键盘事件 “DOM2级事件”最初规定了键盘事件,但是最后在定稿时又删除了相应内容 所以键盘事件被放入了DOM3级事件的规范中 总的来说有三个键盘事件: keydo ...

随机推荐

  1. TypeError: unsupported operand type(s) for +: 'float' and 'decimal.Decimal'

    TypeError: unsupported operand type(s) for +: 'float' and 'decimal.Decimal' 浮点型和双精度类型 相加报错 from deci ...

  2. CentOS7 Failed to start LSB: Bring up/down解决方法

    刚刚装好的虚拟机突然不能上网了,报错很诡异,具体报错如下: /etc/init.d/network restart Restarting network (via systemctl):  Job f ...

  3. CNA, FCoE, TOE, RDMA, iWARP, iSCSI等概念及 Chelsio T5 产品介绍 转载

    CNA, FCoE, TOE, RDMA, iWARP, iSCSI等概念及 Chelsio T5 产品介绍 2016年09月01日 13:56:30 疯子19911109 阅读数:4823 标签:  ...

  4. Redis数据类型-Strings

    Redis 简介 REmote DIctionary Server(Redis) 是一个由Salvatore Sanfilippo写的key-value存储系统. Redis是一个开源的使用ANSI ...

  5. 服务管理之NFS

    目录 NFS简介 1.1 nfs特点 1.4 nfs的应用场景 4. nfs管理 NFS简介 1.1 nfs特点 NFS(Network File System)即网络文件系统,是FreeBSD支持的 ...

  6. PPS--在download DN出现的问题注意:

    1,DN的下载条件:(没有删除没有下载) PPSL=’N’(PPSL有两个值,N时是指这个DN还没有下载) DEL_FLAG<>’Y’(DEL_FLAG有两个值,Y时说明已经删除,不会下载 ...

  7. C#的split分割的举例

    下面列举了split分割字符串的几种示例: string te = ";"; string re = "a;b"; string se = "a&qu ...

  8. C# WPF 通过委托实现多窗口间的传值

    在使用WPF开发的时候就不免会遇到需要两个窗口间进行传值操作,当然多窗口间传值的方法有很多种,本文介绍的是使用委托实现多窗口间的传值. 在上代码之前呢,先简单介绍一下什么是C#中的委托(如果只想了解如 ...

  9. Chapter5_初始化与清理_数组初始化与可变参数列表

    一.数组初始化 数组是相同类型的,用一个标识符名称封装到一起的一个对象序列或基本类型数据序列.编译器是不允许指定数组的长度的,当使用语句int[] a时,拥有的只是一个符号名,即一个数组的引用,并不拥 ...

  10. angular点击查看更多(简单demo)

    今天来跟大家分享一个小的demo,一般网页浏览到底部的时候会有一个点击加载更多的按钮,之前一直纠结怎么写这个,今天学习angular时发现可以用组件来实现这么一个小的效果,大家有兴趣的话可以看一下. ...