`
piaoyun29
  • 浏览: 46163 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

Flex中DynamicEvent和自定义事件

    博客分类:
  • flex
阅读更多

     今天在实现例子的时候(下面的例子,在datagrid其中一列里面添加按钮,并执行相应的操作),发现DynamicEvent时候是会出现莫名其妙的东西,还是用静态的Event把握点。不过真正的原因我还是不懂。为什么在Renderer里面,派发DynamicEvent事件,不能被监听到;而派发自定义事件就能被监听的到。在帮助里找到这么段话,不知道是不是这个问题的正解。

      Event 的子类是动态的,这意味着在运行时可以在其实例上设置任意事件属性。 相反,Event 及它的其它子类是非动态的,这意味着只可以设置在这些类中声明的属性。当原型化应用程序时,使用 DynamicEvent 会容易些,因为用户不必提前写入 Event 子类来声明属性。但是,最终应该消除 DynamicEvent 并且写入 Event 子类,因为这样做更加快速,也更加安全。DynamicEvent 相当灵活,以致于当您设置错误的属性或分配给不正确类型的值时,编辑器无法帮助您捕获错误。

      总结:以后要注意这两个的用法。至少一个不行的时候,去尝试另个。然后在大量的实践中体会不同。

      下面的例子是网友写的,也和大家分享下。自己去下载吧。

http://xaajie.iteye.com/blog/434447

本来人家也是写的自定义事件,可是我想我只简单的派发个通知,没有数据,直接用DynamicEvent 就行了,可是事实证明,我错了。。。。。。

private function updatebtn(event:MouseEvent):void{
           dispatchEvent(new UpdateEvent(data)); //这个是自定义事件,renderer所在的组建能监听的到
           dispatchEvent(new DynamicEvent("updata")); // 这个是动态事件,renderer所在的组建能监听不到
}

 

 期待高手指点!

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics