事件类型

Web浏览器中有很多事件类型,“DOM3级事件”规定了以下几类事件

UI事件(用户界面),当用户与页面上的元素交互时触发;

焦点事件,当元素获得或失去焦点时触发

鼠标事件,当用户通过鼠标在页面上执行操作时触发

滚轮事件,当用户使用鼠标滚轮(或类似设备)时触发

文本事件,当在文档中输入文本时触发

键盘事件,当用户通过键盘在页面上执行操作时触发

合成事件,当为IME(输入法编辑器)输入字符时触发

变动事件,当底层DOM结构发生变化时触发

变动名称事件,当元素或属性名变动时触发,已废弃不做介绍

UI事件

UI事件指得是那些不一定与用户操作有关的事件

DOMActivate:表示元素已经被用户操作激活,DOM3级事件中已被废弃

load:页面加载完全后在window上触发,框架都加载完成后在框架集上触发,图像加载完成后在<img>元素上面触发,或者当嵌入的内容加载完毕时在<object>元素上面触发

unload:页面完全卸载后在window上面触发,所有框架卸载后在框架集上触发,或者当嵌入的内容加载卸载时在<object>元素上面触发

abort:在用户停止下载过程时,如果嵌入的内容没有加载完,则在<object>元素上面触发

error:当发生JavaScript错误时,在window上面触发,无法加载图片时在<img>元素上触发,无法加载嵌入内容时在<object>元素上面触发,或者当有一个或者多个框架无法加载时在框架集上面触发

select:当用户选择文本框(<input><textarea>)中的一个或多个字符时触发

resize:当窗口或框架的大小发生变化时在window或框架上面触发

scroll:当用户滚动带滚动条的元素中的内容时,在该元素上面触发。<body>元素中包含所加载页面的滚动条

除了DOMActivate之外,其他事件在DOM2级事件中都归为HTML事件

var isSupported=document.implementation.hasfeature("HTMLEvents","2.0");  //浏览器是否支持DOM2级事件规定的HTML事件

var isSupported=document.implementation.hasfeature("UIEvents","3.0");  //浏览器是否支持DOM3级事件规定的事件

load事件

页面完全加载后(包括所有图像、JavaScript文件、CSS文件等外部资源),就会触发window上面的load事件,有两种方式处理该事件

EventUtil.addHandler(window,"load",function(event){  //window可以替换成从image取得的元素

      alert("Loaded!");

    });

<body onload="alert('Loaded!')">  //body可以替换成img元素

“DOM2级事件”规范,应该在document而非window上面触发load事件,但所有浏览器都在window上面触发,以确保向后兼容

还有一些元素以非标准的方式支持load事件,一下版本浏览器中<script>元素也会触发load事件,以确定Javascript文件是否加载完成,还有<link>元素的load事件(这些不推荐使用)

JavaScript高级程序设计43.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. Android中为窗口定义主题

    在res/values/styles文件夹中定义如下: <style name="myTheme"> <item name="android:windo ...

  2. 带缓冲的IO和不带缓冲的IO

    文件描述符: 文件描述符是一个小的非负整数,是内核用来标识特定进程正在访问的文件 标准输入/输出/出错: shell为每个程序打开了三个文件描述符,STDIN_FILEON,STDOUT_FILEON ...

  3. Headfirst设计模式的C++实现——命令模式(Command)

    先看如果不用命令模式的实现: light.h #ifndef _LIGHT_H_ #define _LIGHT_H #include <iostream> class LIGHT { pu ...

  4. [翻译]ASP.NET Web API的路由

    原文:Routing in ASP.NET Web API 在我们新建一个Web API项目时,会在App_Start文件夹下的WebApiConfig.cs中定义一个默认路由: config.Rou ...

  5. 利用反射生成SQL语句

    // 修改学员信息的方法 public bool ModifyStudent(MODEL.Students model) { // 利用反映获取类对所有属性,用来动态生成SQL语句 StringBui ...

  6. centOS 6.4 vsftpd 配置

    ###########配置流程########### 1 新建一个ftp用户,为了跟vsftp的虚拟用户对应 #useradd  -d /home/vftpuser   -s /sbin/nologi ...

  7. 如何在Html的div+css中去除<li>标签前面小黑点,和ul、LI部分属性方法

    div是很多人做网站都会用到的,但在显示效果时前面总是会有一个小黑点,这个效果很多人不想要,但又不知到如何去除,然而我们可以用以下方法来清除. 1.在CSS中写入代码.找到相关性的CSS,在..li和 ...

  8. Quartz 之 windowService

    (一)创建服务 QuarzService using System.ServiceProcess;using System.Text; using Quartz;using Quartz.Impl; ...

  9. window.onresize 多次触发的解决方法

    用了window.onresize但是发现每次 onresize 后页面中状态总是不对,下面与大家分享下onresize 事件多次触发的解决方法. 之前做一个扩展,需要在改变窗口大小的时候保证页面显示 ...

  10. bss段为什么需要初始化?

    我们都知道bss段需要初始化,但是这是为什么呢? 通过浏览资料,我们都会发现,bss段是不会出现在程序下载文件(*.bin *.hex)中的,因为全都是0.如果把它们出现在程序下载文件中,会增加程序下 ...