UI Events 用户界面事件


Posted in Javascript onJune 27, 2012

UI Events并不是直接与用户行为相关,UI Event 包括如下:

DomActivate:当元素被用户的某些行为激活时,触发该事件,例如用户的鼠标或者键盘事件。这一事件在DOM3级事件中被废弃了,FF2+和chrome支持,犹豫跨浏览器实现机制的不同,不推荐使用这个事件。

load:在window对象上触发是当页面加载完毕之后触发的,在frameset 是当所有的frames都加载完毕之后触发,当指img标签时,是指图片加载完毕之后等等。

unload:在window对象上触发是当页面卸载完毕之后触发的,在frameset 是当所有的frames都卸载完毕之后触发,当指img标签时,是指图片卸载完毕之后等等。

abort:当一个元素没有完全加载完,在用户停止了下载操作之前,而触发。

error:当window的javascript发生错误时触发,当img不能加载是触发,或者object元素不能被加载时触发,当frameset中的一个或多个frame不能被加载时触发,

select:当用户选择textbox中一个或多个字符时触发该事件。

resize:当window或者frame被改变大小的时候触发。

scroll:当用户滚动一个带滚动条的元素时触发。

绝大多数的HTML事件,要么与window对象相关,要么与form控件相关。

判断一个浏览器是否在DOM2级事件上支持HTML事件,可以采用下面的代码:

var isSupport = document.implementation.hasFeature('HTMLEvents','2.0');

若果在dom2级事件上实现的话,将会返回true,否则返回false

var isSupported = document.implementation.hasFeature(“UIEvent”, “3.0”);

在dom3级上同理。

The load Event

load事件可能是javascript中最常用到的。对window对象而言,当网页被完全加载完毕时,触发load事件。总而言之,任何发生在window上的事件可以通过body元素的属性进行访问,因为在HTML中是没有权限访问window元素。

对于img标签当你制定img标签的src属性时,同样可以触发他的load事件。

如下:

EventUtil.addHandler(window, “load”, function(){ 
var image = new Image(); 
EventUtil.addHandler(image, “load”, function(event){ 
alert(“Image loaded!”); 
}); 
image.src = “smile.gif”; 
});

同样也有其他的元素以一种非标准的方式支持load event,如script标签元素,当在 IE9+、FF、Opera、Chrome、Safari3.0+中动态加script并且加载完成时将触发script的load事件,与img元素不同,js文件开始加载是在src属性被赋值之后,而且这个元素已经被加入到document之中。因此Event handler的顺序与src赋值无关。

例子如下:

EventUtil.addHandler(window, “load”, function(){ 
var script = document.createElement(“script”); 
script.type = “text/javascript”; 
EventUtil.addHandler(script, “load”, function(event){ 
alert(“Loaded”); 
}); 
script.src = “example.js”; 
document.body.appendChild(script); 
});

 IE和Opera同样支持link标签的load事件。

The unload Event

与load事件相对的就是 unload事件,这个事件当document完全被卸载的时候触发。典型的例子就是,浏览器从一个一面导航到另一个页面的时候会触发该事件,并且通常是用这个事件来释放内存,避免没有必要的内存占用。与load事件相似,unload事件可以通过两种方式进行创建即通过js和通过HTML属性来创建。

对于unload事件的处理函数要格外的小心,因为自从卸载事件被激发,并不是所有的对象都是可用的,当页面被加载仍然可用。试图操作Dom节点的位置或者改变外观会出现错误。

The resize Event

当浏览器窗口的长度和高度被改变时会触发 resize 事件,这个事件发生在window对象上,注册方式与前两个事件的注册方式相同。

与其他发生在window对象上的事件相同,在dom浏览器中该事件的target指的是document,而IE8 和 更早版本的浏览器中是没有相关属性可以使用的。

在不同的浏览器中resize事件存在这很多不同,在IE safari chrome opera中只要修改一个像素的值,该事件就会被触发。而在FF中只有当重置大小操作停止时才会触发这个事件。并且浏览器的最大 最小化同样会触发此事件。

The scroll Event

虽然scroll事件发生在window对象上,但他也同样适用于页面级元素。在混在模式下,对应的变化反映在<body>元素的scrollLeft和scrollTop属性;在标准模式下,对应的变化发生在<HTML>元素上,除了safari,其他的浏览器都遵守上述的规则,例如:

EventUtil.addHandler(window, “scroll”, function(event){ 
if (document.compatMode == “CSS1Compat”){//标准模式反映在html上。 
alert(document.documentElement.scrollTop); 
} else { 
alert(document.body.scrollTop); 
} 
});
Javascript 相关文章推荐
Javascript中Eval函数的使用
Mar 23 Javascript
JS判断是否360安全浏览器极速内核的方法
Jan 29 Javascript
Bootstrap 附加导航(Affix)插件实例详解
Jun 01 Javascript
Bootstrap基本样式学习笔记之图片(6)
Dec 07 Javascript
js实现文字向上轮播功能
Jan 13 Javascript
微信小程序 两种为对象属性赋值的方式详解
Feb 23 Javascript
详解Vue使用 vue-cli 搭建项目
Apr 20 Javascript
thinkjs 文件上传功能实例代码
Nov 08 Javascript
pageGroup.js实现分页功能
Jul 27 Javascript
Vue 刷新当前路由的实现代码
Sep 26 Javascript
Element的el-tree控件后台数据结构的生成以及方法的抽取
Mar 05 Javascript
ECharts transform数据转换和dataZoom在项目中使用
Dec 24 Javascript
浅谈Javascript鼠标和滚轮事件
Jun 27 #Javascript
浅谈Javascript事件模拟
Jun 27 #Javascript
JS时间选择器 兼容IE6,7,8,9
Jun 26 #Javascript
基于jquery &amp; json的省市区联动代码
Jun 26 #Javascript
jquery命令汇总,方便使用jquery的朋友
Jun 26 #Javascript
Jvascript学习实践案例(开发常用)
Jun 25 #Javascript
来自国外的30个基于jquery的Web下拉菜单
Jun 22 #Javascript
You might like
php不用正则采集速度探究总结
2008/03/24 PHP
php 图片上传类代码
2009/07/17 PHP
PHP数组的交集array_intersect(),array_intersect_assoc(),array_inter_key()函数的小问题
2011/05/29 PHP
利用php做服务器和web前端的界面进行交互
2016/10/31 PHP
php常用字符串String函数实例总结【转换,替换,计算,截取,加密】
2016/12/07 PHP
php 获取xml接口数据的处理方法
2018/05/31 PHP
JQuery入门——用one()方法绑定事件处理函数(仅触发一次)
2013/02/05 Javascript
js中定义一个变量并判断其是否为空的方法
2014/05/13 Javascript
Js中使用hasOwnProperty方法检索ajax响应对象的例子
2014/12/08 Javascript
JavaScript中的类(Class)详细介绍
2014/12/30 Javascript
jQuery实现返回顶部功能
2016/02/23 Javascript
JavaScript类型系统之布尔Boolean类型详解
2016/06/26 Javascript
移动端基础事件总结与应用
2017/01/12 Javascript
webpack学习笔记之优化缓存、合并、懒加载
2017/08/24 Javascript
javascript中的replace函数(带注释demo)
2018/01/07 Javascript
NodeJS 将文件夹按照存放路径变成一个对应的JSON的方法
2018/10/17 NodeJs
微信小程序实现的一键复制功能示例
2019/04/24 Javascript
js实现点击图片在屏幕中间弹出放大效果
2019/09/11 Javascript
layui 上传插件 带预览 非自动上传功能的实例(非常实用)
2019/09/23 Javascript
go和python变量赋值遇到的一个问题
2017/08/31 Python
Django1.9 加载通过ImageField上传的图片方法
2018/05/25 Python
Python2实现的图片文本识别功能详解
2018/07/11 Python
Python基于plotly模块实现的画图操作示例
2019/01/23 Python
Python面向对象之Web静态服务器
2019/09/03 Python
PySide2出现“ImportError: DLL load failed: 找不到指定的模块”的问题及解决方法
2020/06/10 Python
Python使用OpenPyXL处理Excel表格
2020/07/02 Python
python中通过pip安装库文件时出现“EnvironmentError: [WinError 5] 拒绝访问”的问题及解决方案
2020/08/11 Python
银行爱岗敬业演讲稿
2014/05/05 职场文书
小学课外活动总结
2014/07/09 职场文书
加强作风建设心得体会
2014/10/22 职场文书
大学辅导员述职报告
2015/01/10 职场文书
故宫英文导游词
2015/01/31 职场文书
横店影视城导游词
2015/02/06 职场文书
医院保洁员管理制度
2015/08/05 职场文书
MySQL的全局锁和表级锁的具体使用
2021/08/23 MySQL
python的html标准库
2022/04/29 Python