unload事件

与load事件对应的是unload事件,这个事件在文档被完全卸载后触发,只要用户从一个页面切换到另一个页面,就会发生unload事件,最多的情况是清除引用,避免内存泄漏

与load事件类似,也有两种指定onunload事件的处理程序方式

EventUtil.addHandler(window,"unload",function(event){

      alert("Unloaded");

    });

为元素添加特性

<body onunload="alert('Unloaded!')">

根据“DOM2级事件”,应该<body>元素而非window对象上面触发unload事件,不过所有浏览器都在window上实现了unload事件,以确保向后兼容

resize事件

当浏览器窗口被调整宽度或者高度时,就会触发resize事件,同样2种方式

EventUtil.addHandler(window,"resize",function(event){

      alert("Resized");

    });

IE、Safari、Chrome和Opera会在浏览器变化1像素时就触发resize事件,然后随变化不断触发,Firefox则是在停止变化后触发事件,所以要避免大量的计算

浏览器最大化最小化也会触发resize事件

scroll事件

scroll事件在window对象上发生,实际表示的是页面中相应元素的变化,在混杂模式下可以通过<body>元素的scrollLeft和scrollTop来监控这一变化;而在标准模式下,除Safari之外的所有浏览器都会通过<html>元素反映这一变化

EventUtil.addHandler(window,"scroll",function(event){

      if(document.compatMode=="CSS1Compat"){

        alert(document.documentElement.scrollTop);

      }else{

        alert(document.body.scrollTop);

      }

    });

这个事件同样应避免大量计算

焦点事件

焦点事件会在页面获得或失去焦点时触发,有以下6个焦点事件

blur:在元素失去焦点时触发,这个事件不会冒泡,所有浏览器都支持它

focus:在元素获得焦点时触发,这个事件不会冒泡,所有浏览器都支持它

DOMFocusIn:在元素获得焦点时触发,DOM3级事件已废弃,只有Opera支持这个事件

DOMFocusOut:在元素失去焦点时触发,DOM3级事件已废弃,只有Opera支持这个事件

focusin:在元素获得焦点时触发,这个事件与HTML事件focus等价,但它冒泡,IE5.5+、Safari5.1+、Opera11.5+和Chrome支持

focusout:在元素失去焦点时触发,这个事件与HTML事件blur等价,但它冒泡,IE5.5+、Safari5.1+、Opera11.5+和Chrome支持

blur和focus不冒泡是最大的问题,IE的方式被DOM3级事件采纳为标准方式

当焦点从页面中的一个元素移动到另一个元素,会依次触发下列事件:

focusout→focusin→blur→DOMFocusOut→focus→DOMFocusIn

鼠标与滚轮事件

鼠标事件是Web开发中最常用的一类事件,DOM3级事件中定义了9个鼠标事件

click:鼠标单击左键或键盘回车键

dblclick:鼠标双击左键DOM3级将其纳入了规范,

mousedown:按下任意鼠标按钮时触发,不支持键盘触发

mouseenter:鼠标光标从元素外部首次移动到元素范围内时触发,该事件不冒泡。DOM3级将其纳入了规范,IE、Firefox9+和Opera支持这个事件

mouseleave:鼠标光标从元素上方移动到元素范围外时触发,该事件不冒泡。DOM3级将其纳入了规范,IE、Firefox9+和Opera支持这个事件

mousemove:鼠标指针在元素内部移动时重复地触发,不支持键盘触发

mouseout:鼠标指针位于元素上方,用户将其移入另一个元素时触发,另一个元素可能位于前一个元素的外部也可能是这个元素的子元素,不支持键盘触发

mouseover:鼠标指针位于一个元素外部,然后用户将其首次移入另一个元素边界之内时触发,不支持键盘触发

mouseup:释放鼠标按钮时触发,不支持键盘触发

上面的事件除了mouseleave和mouseenter,其余都会冒泡,也可以被取消,取消鼠标事件将会影响浏览器的默认行为

事件与事件之间的联系非常紧密

mousedown→mouseup→click→mousedown→mouseup→click→dblclick

IE8及之前版本有个BUG,IE9修复了该BUG

mousedown→mouseup→click→mouseup→dblclick

检测浏览器是否支持DOM2级事件(除dblclick、mouseenter和mouseleave之外)

var isSupported=document.implementation.hasFeature("MouseEvents","2.0");

检测浏览器是否支持以上所有事件

var isSupported=document.implementation.hasFeature("MouseEvent","3.0");

注意:DOM3级事件的feature名是"MouseEvent",而非"MouseEvents"

鼠标还有一类滚轮事件,mousewheel事件,用于跟踪鼠标滚轮

JavaScript高级程序设计44.pdf的更多相关文章

  1. JavaScript高级程序设计61.pdf

    JSON对象 早期的JSON解析器就是使用JavaScript的eval()函数,ECMAScript5对解析JSON的行为做出了规定,定义了全局对象JSON. JSON对象有2个方法:stringi ...

  2. JavaScript高级程序设计60.pdf

    错误处理 try-catch语句 try{ //可能会导致错误的代码 }catch(error){ //在错误发生时如何处理 } error是一个包含着错误信息的对象,它有一个message属性,保存 ...

  3. JavaScript高级程序设计58.pdf

    15章 使用Canvas绘图 略 16章 HTML5脚本编程 HTML5规范了新的HTML标记和JavaScript API,以便简化创建动态Web界面的工作 跨文档消息传递 简称XDM,指来自不同域 ...

  4. JavaScript高级程序设计57.pdf

    表单序列化 首先了解一下浏览器如何将数据发送给服务器 对表单字段的名称和值进行URL编码,使用和号(&)分隔 不发送禁用的表单字段 只发送勾选的复选框和单选按钮 不发送type为“reset” ...

  5. JavaScript高级程序设计55.pdf

    输入模式 HTML5为文本字段新增了pattern属性,这个属性的值是一个正则表达式,用于匹配文本框中的值 例如,只想在允许在文本字段中输入数值 <input type="text&q ...

  6. JavaScript高级程序设计54.pdf

    过滤输入 对于一些浏览器,可以使用正则表达式里的text()测试用户按下的按键,Firefox和safari(3.1版本之前)会对向上向下.退格键和删除键触发keypress事件,在Firefox中, ...

  7. JavaScript高级程序设计53.pdf

    共有的表单字段方法 每个表单字段都有两个方法:focus()和blur(),其中focus()用于将浏览器焦点设置到表单字段,激活表单字段.可以侦听页面的load事件 EventUtil.addHan ...

  8. JavaScript高级程序设计52.pdf

    表单脚本 表单的基础知识 在HTML中,表单是由<form>元素表示的,在Javascript对应的是HTMLFormElement类型,它继承自HTMLElement,因此具有与其他HT ...

  9. JavaScript高级程序设计50.pdf

    hashchange事件 HTML5新增了hashchange事件,以便在URL的参数列表(及URL中“#”号后面的所有字符串)发生变化时通知开发人员,之所以新增这个事件,是因为在Ajax应用中,开发 ...

随机推荐

  1. Effective C++ 学习总结

    摒弃C的做法采用C++的实现方式 以const和inline代替define 以iostream流代替stdio 以new和delete代替 C++风格注释 内存管理 new和delete, new[ ...

  2. 曾经的10道JAVA面试题

    1.HashMap和Hashtable的区别. 都属于Map接口的类,实现了将惟一键映射到特定的值上.HashMap 类没有分类或者排序.它允许一个null 键和多个null 值.Hashtable ...

  3. c# winform textbox与combox让用户不能输入

    textbox的ReadOnly属性设置为true combox的Enable属性设置为false 运行后效果如下 点击第一个和第二个,会把按钮text赋值给文本框和combox 并且用户不能输入

  4. web前端必须掌握的localStorage

    先自我介绍一下,本人男,27岁,单身,web前端程序员一枚,长期潜伏在幕后,只学不教(貔貅么?),其实主要是工作太忙了,每天忙到11点左右,没有时间写东西,洗洗就睡了.最近赶巧,后端那边出技术瓶颈了, ...

  5. 欢迎使用skymvc框架,简单易用的php框架

    skymvc是一款轻量.简单易用的php mvc框架,经过多个项目实践改良. 特点: 1.mvc架构 2.m.v.c之间可以互相调用 3.简单的路由控制 R("/index.php" ...

  6. delete删除多表

    1.DELETE a.*, aa.* FROM student a, person aa WHERE a.id = aa.city_id AND a.name = '' 2.DELETE a.*, a ...

  7. C语言和C++中动态申请内存

      在C语言和C++的动态内存的使用方法是不同的,在C语言中要使用动态内存要包含一个头文件即 #include<malloc.h> 或者是#include<stdlib.h>  ...

  8. struts2整合jfreechart

    需要的包: struts2-jfreechart-plugin-2.2.1.1.jar jfreechart-1.0.13.jar jcommon-1.0.17.jar 前台jsp页面中可以使用ifr ...

  9. 实现一个JavaScript模块化加载器

    对任何程序,都存在一个规模的问题,起初我们使用函数来组织不同的模块,但是随着应用规模的不断变大,简单的重构函数并不能顺利的解决问题.尤其对JavaScript程序而言,模块化有助于解决我们在前端开发中 ...

  10. ZOJ 2562 More Divisors

    又是个水题,刚刚开始没有用搜索,因为对于反素数有: n=2^t1*3^t2^5^t3*7^t4..... 这里有 t1>=t2>=t3>=t4. 而且相同的因数的情况下,素数越不同越 ...