一般的,只要在属性前加上
[Bindable] 或
[Bindable(event="eventname")]
[Bindable(event="eventname")]
元标记即可
注意:
如果没有标出触发绑定的事件,正如[Bindable],Flex会自动为绑定加上
propertyChange事件,当源数据发生变化时,Flex将自动派发该事件,触发数据绑定。如果修改后数据和源数据“===”也就是全等,那么Flex将不会触发数据绑定。
如果标出的触发绑定的事件,正如[Bindable(event="eventname")],那么在源数据发生改变的时候,必须dispatch出该事件才能触发数据绑定。不论修改后数据和源数据是否全等,Flex都将会触发数据绑定,需要自己编程控制,例如
<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600">
<s:layout>
<s:BasicLayout/>
</s:layout>
<fx:Declarations>
<!-- 将非可视元素(例如服务、值对象)放在此处 -->
</fx:Declarations>
<fx:Script>
<![CDATA[
[Bindable(event="shijianevent")]
private var str:String="null";
private function doTest():void
{
str = textIput1.text;
if(str!="null") //判断和源数据是否相等,不相等则触发绑定
this.dispatchEvent(new Event("shijianevent"));
}
]]>
</fx:Script>
<mx:Text text="{str}" x="80" y="10"/>
<s:Button click="doTest()" x="187" y="67" label="Binding"/>
<s:TextInput x="305" y="4" id="textIput1"/>
<s:Label x="187" y="10" text="输入要绑定的数据:" height="22"/>
</s:Application>
如果没有this.dispatchEvent(new Event("shijianevent"))这句,那么你点击按钮是没有设么作用的。 另外当申明自定义触发事件时,用ChangeWatcher来监控其变化,发现虽然目的源值变了,但是ChangeWatcher却监控不到变化,同样ChangeWatcher也监控不到非共有变量的变化