UI Events 用户界面事件

 更新时间:2012年06月27日 10:33:23   作者:  
UI即User Interface(用户界面)的简称。UI设计则是指对软件的人机交互、操作逻辑、界面美观的整体设计
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);
}
});

相关文章

  • 小程序实现计时器小功能

    小程序实现计时器小功能

    这篇文章主要为大家详细介绍了小程序实现计时器小功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-09-09
  • 分享JS表单验证源码(带错误提示及密码等级)

    分享JS表单验证源码(带错误提示及密码等级)

    这篇文章主要介绍了JS表单验证源码(带错误提示及密码等级),代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-01-01
  • JS实现日期时间动态显示的方法

    JS实现日期时间动态显示的方法

    这篇文章主要介绍了JS实现日期时间动态显示的方法,涉及JavaScript基于时间函数定时操作页面元素属性的相关技巧,非常简单实用,需要的朋友可以参考下
    2015-12-12
  • JavaScript简介

    JavaScript简介

    这篇文章主要介绍了JavaScript简介,都是非常基础的内容,有需要的小伙伴参考下吧。
    2015-02-02
  • javascript模拟php函数in_array

    javascript模拟php函数in_array

    就是判断一个元素是否存在于数组中的函数,既然js里string都有indexOf函数,为什么不在Array对象里设置一个这样的函数呢,其实就用indexOf这个思想挺好的,不知道制定JS标准的人是基于什么考虑,把这样一个如此常用的功能没考虑在内的。
    2015-04-04
  • JavaScript数据操作_浅谈原始值和引用值的操作本质

    JavaScript数据操作_浅谈原始值和引用值的操作本质

    下面小编就为大家带来一篇JavaScript数据操作_浅谈原始值和引用值的操作本质。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-08-08
  • 前端换行、空格的多种表现形式代码示例

    前端换行、空格的多种表现形式代码示例

    这篇文章主要介绍了多种在HTML、CSS和JavaScript中实现换行和空格处理的方法,这些方法可以帮助开发者在不同的场景下控制文本的换行和空格显示,需要的朋友可以参考下
    2025-01-01
  • 利用JS测试目标网站的打开响应速度

    利用JS测试目标网站的打开响应速度

    本文简单说明利用JS来测试目标网站的打开响应速度,方法简单明了大家一看就明白并附上了脚本源码
    2017-12-12
  • 微信小程序picker选择器获取值的2种方法示例

    微信小程序picker选择器获取值的2种方法示例

    picker为用户提供了多个选择,用户选了其中一种,但仍是需要有东西去告诉后台用户选了什么,下面这篇文章主要给大家介绍了关于微信小程序picker选择器获取值的2种方法,需要的朋友可以参考下
    2023-03-03
  • 详解处理bootstrap4不支持远程静态框问题

    详解处理bootstrap4不支持远程静态框问题

    这篇文章主要介绍了详解处理bootstrap4不支持远程静态框问题,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-07-07

最新评论