flex组件的生命周期

flex组件的生命周期分为三个阶段:初始、更新、销毁阶段

 

下面来看 Button组件的生命周期是怎样的?

如下代码:(Flash Builder4)

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" 
 3                xmlns:s="library://ns.adobe.com/flex/spark" 
 4                xmlns:mx="library://ns.adobe.com/flex/mx" 
 5                minWidth="955" minHeight="600">
 6     <fx:Declarations>
 7         <!-- Place non-visual elements (e.g., services, value objects) here -->
 8     </fx:Declarations>
 9     <s:Button id="btnTest" label="Submit">    </s:Button>
10 </s:Application>

以上转换as3代码:

 

1 var btnTest:Button = new Button();
2 btnTest.label= "Submit";
3 vgpTest.addChild(btnTest);

 

一。初始阶段

 

  • Construction
  • Construction是组件构造阶段,组件的构造器不能有必须的参数。在构造函数中可以添加事件监听器,初始化属性。这个阶段只做很少的事情。

  • Configuration
  • Configuration是组件的配置阶段,组件的属性,事件回调函数,样式和效果定义都在这个阶段完成。你不应该把这些任务推迟到Attachment和Initlization阶段之后。

  • Attachment
  • Attachment阶段是把该组件追加到显示列表当中,一个Flex组件会被一个Flex容器IContianer以addChild方法添加到显示列表当中。

  • Initlization
  • 在Initlization初始化阶段,组件会执行一次完整的invalidation/validation周期。这个阶段做的工作流程是:

    • 发出preinitialize事件。
    • 执行方法createChildren()
    • 发出initialize事件。
    • 行一次完整的invalidation/validation周期。
    • 发出creationComplete事件。

     

    二。更新阶段

     

    用户可能会与组件产生交互,组件的位置大小可能改变,样式可能被重新赋值,也可能获得焦点或者被禁用等等。这些情况的发生都用影响到组件外观的变化。所以组件需要重绘自身来响应这些变化。

  • Invalidation
  • 如果一个组件的属性改变,它可能就会标记组件为失效状态。

  • Validation
  • 一个组件被标记失效后,会验证是否需要更新组件,如果需要会调用相关的方法来更新。组件有三个极其重要的方法来更新自己:

    • commitProperties()
    • measure()
    • updateDisplayList(unscaledWidth,unscaledHeight)

    除了这三个方法,还有一个重要的方法是styleChanged(styleName),当某个样式改变时,styleChanged被调用,然后执行Invalidation标记组件。如果你有自定义一个组件,有一些法则必要得遵守:

    不要在子类中显式调用commitProperties,measure和updateDisplayList这三个方法,你要做的是override,而不是call。如果你添加了新的样式,同样是要继承styleChanged方法,加入自己的逻辑。

     

    三。销毁阶段

     

  • Detachment
  • 当不需要这个组件时,把它从显示列表中移出。把组件从一个容器中移出再添加到另一个容器中比创建新的组件有更小的开销。

  • Garbage Collection
  • 如果组件不再被引用时,它就成为符合垃圾回收的对象了,所以垃圾回收的第一条准则是不再有活动的引用。
    更加值得注意的是第二条准则,即不包含使用了强引用的事件监听器,Dictionary和Timer。
    所以尽量使用弱引用是多么重要,但是同样,小心你的弱引用在不该回收的时刻被回收了。例如对函数中的临时变量使用弱引用,你可能得不到你想要的异步结果。

     

    posted on 2012-02-24 10:18  SageChen  阅读(826)  评论(0编辑  收藏  举报

    导航