jQuery实战---谈事件

今天买到了最新出版的jQuery实战,第一件事情就是看看事件这一章,网景NetScape的Dom0级的事件模型,开辟了Javascript事件的新时代,直到W3C出来Dom2级的事件模型标准,IE依然是走自己的路,让别人说去吧,不过我觉得IE应该要遵循W3C标准,也许微软为了市场地位还是没有完全遵循W3C标准,但从IE7已经开始接近W3C标准,希望微软的路线更接近开发人员会更好,这样JS开发人员就可以更轻松的写自己的业务了。

好了,废话不多少了,先看看jQuery如何完成Dom0级的事件:

 

Code

 

要出去了,回来继续写了!

接着写一些,说事件必然要说说Event参数,IE浏览器的event对象是通过window.event来获取的,一般获取的方式:

if (!event) event = window.event;

为什么我们要获得这个参数呢,因为这个event实例上保存大量当前操作的信息,包括像当前元素、鼠标事件坐标、键盘的键值等等。

那如果我们像获取当前元素该如何来处理呢,我们来看看以下的例子:

var target = (event.target) ? event.target : event.srcElement;

为什么我们需要一个三元的运算符来获取它呢,这就是IE所造成,在IE浏览器里存储srcElement属性,而在W3C标准中是取

event.target属性的。

那接下来我们会将到有关于事件捕获和事件冒泡,两个重要的事件机制。

我们知道Html页面脚本是树状的,我们称之为Dom树,如果我们写了一段Html:

<html>

     <head>

          <title>测试</title>

     </head>

     <body>

          <form>

               <div>这是一个简单的Dom树</div>

          </form>

     </body>

</html>

我们通常称Html的头为树的顶(也称为树的根),简单的方式我们可以将这段代码抓成图片,并顺时针旋转90度,就可以看到Dom树的效果了。

对于事件的捕获简单的说就是从树顶部,开始向下寻找你要找的对象元素(也可以简单看为id或tag),而对于事件冒泡呢,简单说是

从当前元素向Dom树的顶部传播,一直到Dom的顶部,这就是常说的事件冒泡阶段了。

以上所说都是W3C标准的事件模型所支持的,对于IE事件模型,虽然微软提供了与这两个阶段相同的专有接口,但是不支持Dom2级事件模型,可惜啊!

痛苦啊!作为前段开发员又做大量的兼容工作了,标准的挂接事件的方法为addEventListener(),而IE提供的是attachEvent()方法。

好了,今天就说到这了,到这里吧,就到这里!

posted @ 2009-02-22 10:05  Adam.Zhao  阅读(2199)  评论(11编辑  收藏  举报