JavaScript高级程序设计44.pdf
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的更多相关文章
- JavaScript高级程序设计61.pdf
JSON对象 早期的JSON解析器就是使用JavaScript的eval()函数,ECMAScript5对解析JSON的行为做出了规定,定义了全局对象JSON. JSON对象有2个方法:stringi ...
- JavaScript高级程序设计60.pdf
错误处理 try-catch语句 try{ //可能会导致错误的代码 }catch(error){ //在错误发生时如何处理 } error是一个包含着错误信息的对象,它有一个message属性,保存 ...
- JavaScript高级程序设计58.pdf
15章 使用Canvas绘图 略 16章 HTML5脚本编程 HTML5规范了新的HTML标记和JavaScript API,以便简化创建动态Web界面的工作 跨文档消息传递 简称XDM,指来自不同域 ...
- JavaScript高级程序设计57.pdf
表单序列化 首先了解一下浏览器如何将数据发送给服务器 对表单字段的名称和值进行URL编码,使用和号(&)分隔 不发送禁用的表单字段 只发送勾选的复选框和单选按钮 不发送type为“reset” ...
- JavaScript高级程序设计55.pdf
输入模式 HTML5为文本字段新增了pattern属性,这个属性的值是一个正则表达式,用于匹配文本框中的值 例如,只想在允许在文本字段中输入数值 <input type="text&q ...
- JavaScript高级程序设计54.pdf
过滤输入 对于一些浏览器,可以使用正则表达式里的text()测试用户按下的按键,Firefox和safari(3.1版本之前)会对向上向下.退格键和删除键触发keypress事件,在Firefox中, ...
- JavaScript高级程序设计53.pdf
共有的表单字段方法 每个表单字段都有两个方法:focus()和blur(),其中focus()用于将浏览器焦点设置到表单字段,激活表单字段.可以侦听页面的load事件 EventUtil.addHan ...
- JavaScript高级程序设计52.pdf
表单脚本 表单的基础知识 在HTML中,表单是由<form>元素表示的,在Javascript对应的是HTMLFormElement类型,它继承自HTMLElement,因此具有与其他HT ...
- JavaScript高级程序设计50.pdf
hashchange事件 HTML5新增了hashchange事件,以便在URL的参数列表(及URL中“#”号后面的所有字符串)发生变化时通知开发人员,之所以新增这个事件,是因为在Ajax应用中,开发 ...
随机推荐
- (转)Xcode 中设置部分文件ARC支持
ARC是什么 ARC是iOS 5推出的新功能,全称叫 ARC(Automatic Reference Counting).简单地说,就是代码中自动加入了retain/release,原先需要手动添加的 ...
- AJAX 简单上手
AJAX简介 没有AJAX会怎么样?普通的ASP.Net每次执行服务端方法的时候都要刷新当前页面,如实现显示服务器的时间每次都要刷新页面的坏处:页面刷新打断用户操作.速度慢.增加服务器的流量压力.如果 ...
- 每天一条linux命令——crontab
crontab命令被用来提交和管理用户的需要周期性执行的任务,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务工具,并且会自动启动crond进程,crond进程每分钟会定期检查 ...
- open()函数
STDOUT_FILENO 1 标准输入 STDIN_FILENO 0 标准输出 STDERR_FILENO 2 标准错误 在/proc目 ...
- 织梦DedeCMS网站地图模板
亲和百度蜘蛛,分页多层次特色,织梦系统最好用的网站地图! 用 DedeCMS(织梦) 系统搭建的网站多数都是以优化为主要目标的网站类型,既然是优化站 SEO 手段就离不开为网站设置网站地图.可是 De ...
- 股票API
实时股票数据接口大全 股票数据的获取目前有如下两种方法可以获取:1. http/javascript接口取数据2. web-service接口 1.http/javascript接口取数据 1.1Si ...
- asp.net学习资源汇总
名称:快速入门地址:http://chs.gotdotnet.com/quickstart/描述:本站点是微软.NET技术的快速入门网站,我们不必再安装.NET Framework中的快速入门示例程序 ...
- 小波变换 C++ opencv 实现
小波变换 C++ opencv 实现 小波简介: http://www.blogbus.com/shijuanfeng-logs/221293135.html 源码: /// 小波变换 Mat W ...
- uva 11437 - Triangle Fun
计算几何: 直线交点: #include<cstdio> using namespace std; struct node { double x,y; node(,):x(x),y(y){ ...
- DHTMLX 前端框架 建立你的一个应用程序教程(一)
介绍 从这里下载官网 示例 此教程包含是多方面的: 1.如何在页面上添加标准的dhtmlx组建 2.如何在页面上组织组件 3.如何添加过滤 4.如何从服务器端获取数据填充组建 5.如何保存用户修改的数 ...