在什么时候才会用到fireEvent方法呢?

简介:

  在DHTML开发中,微软在其DOM中为每个元素实现了一个fireEvent方法。我们知道HTML的事件onXXX可以由系统(IE环境)来管理和触发,也可以直接执行事件的handler,比如onclick,如果被赋予事件处理函数,我们可以用element.onclick()来执行事件处理函数。那么fireEvent用来干嘛呢?

    在MSDN中fireEvent的描述很简单:Fires a specified event on the object.
    bFired = object.fireEvent(sEvent [, oEventObject])

    并且MSDN给出了一个使用fireEvent的示例:

None.gif < HTML >
None.gif     < HEAD >
ExpandedBlockStart.gif         < SCRIPT >
InBlock.gif        
function  fnFireEvents()
ExpandedSubBlockStart.gif        
{
InBlock.gif            div.innerText 
=   " The cursor has moved over me! " ;
InBlock.gif            btn.fireEvent(
" onclick " );
ExpandedSubBlockEnd.gif        }

ExpandedBlockEnd.gif        
</ SCRIPT >
None.gif     </ HEAD >
None.gif     < BODY >
None.gif         < h1 >Using the fireEvent method </ h1 >
None.gif        By moving the cursor over the DIV below, the button is clicked.
None.gif         < DIV  ID ="div"  onmouseover ="fnFireEvents();" >
None.gif            Mouse over this!
None.gif         </ DIV >
None.gif         < BUTTON  ID ="btn"  ONCLICK ="this.innerText='I have been clicked!'" >Button </ BUTTON >
None.gif     </ BODY >
None.gif </ HTML >
None.gif

    这个示例非常的简单,也完全说明了fireEvent的用法。不过这个示例有一点误导我们,从而让我们不容易发现frieEvent更有价值的使用方法。由于button的onclick事件被赋予语句:this.innerText = 'I have been clicked!',这里很容易误导我们,fireEvent产生的是执行了btn.onclick()的效果。嗯,确实是这个效果,但是意义却完全不同,btn.onclick()只是一个函数调用,它的执行必须依赖于用户对其赋值,否则btn.onclick为null,是不能执行btn.onclick()的。而fireEvent('onclick')的效果,"等同于"鼠标在button元素上进行了点击。

    由于IE的事件处理是bubble up方式,fireEvent(sEvent)就显得更加的有意义了,如果我们在一个table元素<table>中监听事件,比如onclick,当点击不同的td做出不同的响应时。如果使用程序来模拟,只能使用fireEvent这种方式,示例如下:

None.gif < table  border ="1"  onclick ="alert(event.srcElement.innerText);" >
None.gif     < tr >
None.gif         < td  id ="abc" >abc </ td >
None.gif         < td  id ="def" >def </ td >
None.gif     </ tr >
None.gif </ table >
None.gif < button  onclick ="abc.fireEvent('onclick')" >
None.gif    abc </ button >
None.gif < button  onclick ="def.fireEvent('onclick')" >
None.gif    def </ button >

    使用abc.onclick()和def.onclick()将得到"Object doesn't support this property or method"异常。

   
abc def

     

    知道了fireEvent的用法,那么我们用它来做什么呢?在开发具有复杂事件处理动作组件时。有时我们需要从程序中去触发一个本身因该鼠标或键盘触发的事件,比如在TreeView控件中,我们一般是使用鼠标点击来Expand&Collapse一个结点,如果我们要用程序代码来实现这个操作怎么办呢?当然直接执行事件处理函数是可以的,不过如果事件处理函数依赖于event变量中的状态值,那么就必须使用fireEvent方法。

    原来我曾经说过,因该把事件处理的函数封装起来,便于直接调用。比如上面说到的TreeView节点的Expand和Collapse,我在TreeView控件中都是把它们封装成两个函数Expand和Collapse,在节点被点击时,执行:
None.gif OpIcon.onclick =  function()
None.gif {
None.gif      var objNode =  this.Object;
None.gif      if ( objNode.m_IsExpanded )
None.gif         objNode.Collapse();
None.gif     else
None.gif         objNode.Expaned();
None.gif }

    这样一来,在程序中控制Expand和Collapse也就是分别执行函数而已。不过后来发现既然DOM中有fireEvent方法,似乎我在"动态载入数据的无刷新TreeView控件(4)"中的某些想法也不是很必要了。


本文转自博客园鸟食轩的博客,原文链接:http://www.cnblogs.com/birdshome/,如需转载请自行联系原博主。

目录
相关文章
|
8月前
|
Java C语言
|
9月前
|
C#
C#中的方法
C#中的方法
50 0
|
9月前
|
SQL 数据库
SqlCommand.ExecuteNonQuery 方法
SqlCommand的一个类,用于包含update、insert、delete、select的Transact-sql 语句中来修改数据库中的数据,并返回结果。
|
9月前
|
C#
C#视频—方法
C#视频—方法
v-for的四种方法
v-for的四种使用方法分别是: 1.使用v-for循环一个简单的数组 2.使用v-for循环一个复杂的数组 3.使用v-for循环对象 4.v-for循环一个迭代的数字
|
10月前
|
存储 数据处理 数据库
结构化分析方法
1.概述 结构化方法是世界上第一个软件开发方法学,用来指导从需求分析、到设计开发各个阶段该怎么样做,采用什么样的方法,产出什么样的结果,从而保证整个软件开发周期可控。
84 0
|
JavaScript 前端开发
getMonth() 方法
getMonth() 方法
124 0
|
Java 开发者
想求问一下,瑜伽的练习方法
沐鸣如果勉强坐得太久,很容易因为身体酸麻涨痛而对瑜伽坐姿练习发生退却之心,所以最初练习以“短时多次”为宜,慢慢就能享受到打坐的乐趣了练习瑜伽坐姿时,要坚持腰背挺直,下颗内收,使头部、颈部和脊椎保持在一条直线上。此外,练习全莲花坐时,注意膝盖不要上浮。>