UI Events 用户界面事件_javascript技巧

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);
}
});

时间: 2024-11-05 17:18:59

UI Events 用户界面事件_javascript技巧的相关文章

浅谈移动端之js touch事件 手势滑动事件_javascript技巧

现分享一篇关于touch的文章,望指教! 原理: 当开始一个touchstart事件的时候,获取此刻手指的横坐标startX和纵坐标startY: 当触发touchmove事件时,在获取此时手指的横坐标moveEndX和纵坐标moveEndY;最后,通过这两次获取的坐标差值来判断手指在手机屏幕上的滑动方向. 具体代码如下: $("body").on("touchstart", function(e) { e.preventDefault(); startX = e.

浅谈javascript的Touch事件_javascript技巧

js的touch事件,一般用于移动端的触屏滑动 复制代码 代码如下: $(function(){document.addEventListener("touchmove", _touch, false);}) function _touch(event){alert(1);} touchstart:当手指触摸屏幕时触发:即使已经有一个手指放在了屏幕上也会触发. touchmove:当手指在屏幕上滑动时连续的触发.在这个事件发生期间,调用preventDefault()可阻止滚动. to

javascript 鼠标滚轮事件_javascript技巧

今天在网上找来了响应滚轮的函数并改写成下面的类 复制代码 代码如下: function wheelEvent(obj, handle) { this.handle = handle; // different events between Firefox and IE window.addEventListener ? obj.addEventListener("DOMMouseScroll", this.wheel, false) : (obj.onmousewheel = this

js实现touch移动触屏滑动事件_javascript技巧

移动端触屏滑动的效果其实就是图片轮播,在PC的页面上很好实现,绑定click和mouseover等事件来完成.但是在移动设备上,要实现这种轮播的效果,就需要用到核心的touch事件.处理touch事件能跟踪到屏幕滑动的每根手指. 以下是四种touch事件 touchstart: //手指放到屏幕上时触发 touchmove: //手指在屏幕上滑动式触发 touchend: //手指离开屏幕时触发 touchcancel: //系统取消touch事件的时候触发,这个好像比较少用 每个触摸事件被触发

JavaScript控制浏览器全屏及各种浏览器全屏模式的方法、属性和事件_javascript技巧

HTML 5中的full screen,目前可以在除IE和opera外的浏览器中使用 ,有的时候用来做全屏API,游戏呀,等都很有用.先看常见的API  element.requestFullScreen()  作用:请求某个元素element全屏 Document.getElementById("myCanvas").requestFullScreen()   这里是将其中的元素ID去请求fullscreen 退出全屏   document.cancelFullScreen() Do

javascript中传统事件与现代事件_javascript技巧

大家都知道,IE中的现代事件绑定(attachEvent)与W3C标准的(addEventListener)相比存在很多问题, 例如:内存泄漏,重复添加事件并触发的时候是倒叙执行等. 下面是用传统事件的方法来处理封装事件的绑定: addEvent.ID = 1; // 事件计数器 function addEvent(obj, type, fn){ if(obj.addEventListener){ obj.addEventListener(type, fn, false); } else { /

使用js判断TextBox控件值改变然后出发事件_javascript技巧

复制代码 代码如下: <script language="javascript" type="text/javascript">     var firsty;//最开始的加载页面时年和月    var firstm;     var secondy;//当onchange触发后的值    var secondm;    var panduan=0;//判断改变了没有     function onloadload()//给全局变量赋最初值 在页面onl

js判断iframe内的网页是否滚动到底部触发事件_javascript技巧

之前有个需求是要判断iframe内的网页是否滚动到底部触发事件, 网上找了许多资料都是说在当前页面下的, 索性就自己研究了一下, 找到了解决方法. clientHeight:这个元素的高度,占用整个空间的高度 offsetHeight:是指元素内容的高度 scrollTop:可以理解为滚动条可以滚动的长度 以下是源代码 复制代码 代码如下: <iframe src="~/Files/3.html" id="iframepage" width="825

浅谈JavaScript的事件_javascript技巧

1.事件流     事件流描述的是从页面中接收事件的顺序.但是IE提出的是冒泡流,而Netscape Communicator提出的是捕获流. JavaScript事件流 2.事件冒泡(event bubbling)     事件开始由最具体的元素(嵌套层次最深的那个节点)接收,然后逐级向上传播为较不为具体的节点(文档).如下: 复制代码 代码如下: <html>     <head>         <title>事件冒泡</title>     <