亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Flex Data Binding詳解

 更新時間:2009年09月20日 17:47:23   作者:  
Data BindIng簡單的說就是當(dāng)綁定源屬性發(fā)生變化時,F(xiàn)lex 會把綁定源變化后屬性的值賦給目的物的屬性。做到了數(shù)據(jù)同步。
Data BindIng 什么時候發(fā)生:

1.在綁定源屬性值發(fā)生改變時發(fā)生。
2.在綁定源發(fā)出initialize事件時綁定發(fā)生一次。

讓屬性具有可綁定功能:

一般的,只要在屬性前加上
[Bindable] 或
[Bindable(event="eventname")]
元標(biāo)記即可
注意:
如果沒有標(biāo)出觸發(fā)綁定的事件,正如[Bindable],F(xiàn)lex會自動為綁定加上propertyChange事件,當(dāng)源數(shù)據(jù)發(fā)生變化時,F(xiàn)lex將自動派發(fā)該事件,觸發(fā)數(shù)據(jù)綁定。如果修改后數(shù)據(jù)和源數(shù)據(jù)“===”也就是全等,那么Flex將不會觸發(fā)數(shù)據(jù)綁定。
如果標(biāo)出的觸發(fā)綁定的事件,正如[Bindable(event="eventname")],那么在源數(shù)據(jù)發(fā)生改變的時候,必須dispatch出該事件才能觸發(fā)數(shù)據(jù)綁定。不論修改后數(shù)據(jù)和源數(shù)據(jù)是否全等,F(xiàn)lex都將會觸發(fā)數(shù)據(jù)綁定,需要自己編程控制,例如:
<mx:Script>
<![CDATA[
[Bindable(event="hhhh")]
private var ss:String="aaa";

private function doTest():void
{
ss="bbb";
if(ss!=="aaa") / /判斷和源數(shù)據(jù)是否相等,不相等則觸發(fā)綁定
this.dispatchEvent(new Event("hhhh"));
}
]]>
</mx:Script>
<mx:Text text="{ss}"/>
<mx:Button click="doTest()"/>
如果沒有this.dispatchEvent(new Event("hhhh"))這句,那么你點擊按鈕是沒有設(shè)么作用的。 另外當(dāng)申明自定義觸發(fā)事件時,用ChangeWatcher來監(jiān)控其變化,發(fā)現(xiàn)雖然目的源值變了,但是ChangeWatcher卻監(jiān)控不到變化,同樣ChangeWatcher也監(jiān)控不到非共有變量的變化。關(guān)于ChangeWatcher,下面會提到。
綁定函數(shù)——Functions,對象——Object,數(shù)組——Arrays
函數(shù):
你可以在{}中直接使用函數(shù)。例如:<mx:Text text="{Matn.random()*ss}"/>
上面這個沒有什么好講的,關(guān)于函數(shù)綁定下面這個比較重要:
<mx:Script>
<![CDATA[
public var ss:String="aaa";

[Bindable(event="hhhh")]
private function gg():String
{
return ss;
}

private function doTest():void
{
ss=Math.random().toString();
this.dispatchEvent(new Event("hhhh"));
}
]]>
</mx:Script>

<mx:Text text="{gg()}"/>
<mx:Button click="doTest()"/>
這樣給函數(shù)加一個[bindable],便使函數(shù)具有綁定功能,但是如果不申明自定義觸發(fā)事件,只能在組件初始化時綁定一次,點擊以上按鈕是沒有什么作用的。大家可以自己試試。

還有g(shù)etter和setter函數(shù),比較重要,給getter或setter函數(shù)加上[bindable],用不著兩個都加,加一個就可以了,例如:
<mx:Script>
<![CDATA[
public var ss:String="aaa";

[Bindable]
public function get gg():String
{
return ss;
}

public function set gg(value:String):void
{
ss=value;
}

private function doTest():void
{
gg=Math.random().toString();
this.dispatchEvent(new Event("hhhh"));
}
]]>
</mx:Script>

<mx:Text text="{gg}"/>
<mx:Button click="doTest()"/>
同樣能達(dá)到綁定效果,如果只有一個getter方法,那么要想實現(xiàn)數(shù)據(jù)綁定,就需要申明自定義觸發(fā)事件了,大家可以自己試試。
對象:
對象綁定最重要的是搞清楚怎么申明才能使其屬性具有綁定功能,例如:
申明對象 NonBindableObject
//[bindable] 先注釋掉這行,測試
public class NonBindableObject extends Object
{

public function NonBindableObject() {
super();
}

public var stringProp:String = "String property";

public var intProp:int = 52;
}
綁定
<mx:Script>
<![CDATA[
[Bindable]
public var myObj:NonBindableObject = new NonBindableObject();
[Bindable]
public var anotherObj:NonBindableObject =
new NonBindableObject();
public function initObj():void {
anotherObj.stringProp = 'anotherObject';
anotherObj.intProp = 8;
}
]]>
</mx:Script>
<mx:Text id="text1" text="{myObj.stringProp}"/>
<mx:Text id="text2" text="{myObj.intProp}"/>
<mx:Button label="改變 myObj.stringProp"
click="myObj.stringProp = 'new string';"/>

<mx:Button label="改變 myObj.intProp"
click="myObj.intProp = 10;"/>

<mx:Button label="Change myObj"
click="myObj = anotherObj;"/>
如果在申明對象時沒有在類前加上[bindable]標(biāo)簽,那么該對象的所有屬性是不能被綁定的,也就是說當(dāng)對象屬性發(fā)生變化時,不會觸發(fā)綁定,所以點擊前兩個按鈕都是沒有用的,只有當(dāng)該對象本身發(fā)生變化時,才能夠觸發(fā)綁定,正如第三個按鈕的操作。
現(xiàn)在取消第一行的注釋,使對象屬性可綁定,那么再點前兩個按鈕試試。只要給對象加上[Bindable]元標(biāo)記,那么會使該對象的所有公有屬性——public和擁有g(shù)etter和setter方法的屬性具有綁定功能。
數(shù)組:
如果把數(shù)組作為綁定對象,那么最好使用ArrayCollection對象,因為當(dāng)使用ArrayCollection對象的一些API來操作數(shù)組會觸發(fā)數(shù)據(jù)綁定,如:ArrayCollection.addItem(), ArrayCollection.addItemAt(), ArrayCollection.removeItem(), and ArrayCollection.removeItemAt()方法 ,不然要直接使用Array的話,只用當(dāng)Array本身發(fā)生變化時才觸發(fā)數(shù)據(jù)綁定,當(dāng)數(shù)組中某一屬性發(fā)生變化時是不會觸發(fā)數(shù)據(jù)綁定的。例如:
<mx:Script>
<![CDATA[
import mx.collections.ArrayCollection;
[Bindable]
public var myAC:Array =["One", "Two", "Three", "Four"];

[Bindable]
public var myAC2:Array =["One1", "Two1", "Three1", "Four1"];
]]>
</mx:Script>
<mx:Text id="text1" text="{myAC[0]}"/>
<mx:Text id="text2" text="{myAC.getItemAt(0)}"/>
<mx:Button id="button1"
label="改變某一屬性"
click="myAC[0]='new One'"/>
<mx:Button id="button2"
label="改變對象"
click="myAC=myAC2"/>
當(dāng)使用[]形式來申明數(shù)組時,必須使用ArrayCollection的API方法來實現(xiàn)數(shù)據(jù)綁定,所以當(dāng)你點擊第一個按鈕時,text2發(fā)生了改變,而text1沒有。
數(shù)據(jù)綁定除了用[Bindable]標(biāo)簽來申明以外,也可以用<mx:Binding/>組件和ActionScript實現(xiàn)。
用<mx:Binding/>,例如:
<mx:binding source="text1.text" destination="text2.text"/>
<mx:binging source="text2.text" destination="text1.text"/>
<mx:TextInput id="text1"/>
<mx:TextInput id="text2"/>
source為綁定源,destination為目的源,按上面的寫法,不論是text1還是text2發(fā)生變化,都會引起對方的變化。細(xì)心的你也許會想這不會引起死循環(huán)嗎?答案是否定的,不會引起死循環(huán)。我想應(yīng)該是Flex內(nèi)部的機制已經(jīng)優(yōu)化了這種情況,讓其只觸發(fā)一次。
用ActionScript來綁定:
1.使用bindProperty()。
bindProperty(site:Object, prop:String,host:Object, chain:Object,commitOnly:Boolean = false):ChangeWatcher,例如:
var myc:ChangeWatcher=BindingUtils.bindProperty(text2,"text",text1,"text");
即當(dāng)text1的值發(fā)生變化時text2也跟著變,site為目的對象,prop為目的屬性,host為綁定源,china為綁定源屬性鏈——關(guān)于屬性鏈下面再講,commitOnly默認(rèn)為False,即不管是確認(rèn)事件還是未確認(rèn)事件都將觸發(fā)綁定,而為True時,只有確認(rèn)事件才能觸發(fā)綁定,這個一般用不到,和Flex自身的事件機制有關(guān),如果為false的話,當(dāng)數(shù)據(jù)改變時將觸發(fā)兩次綁定事件,當(dāng)為True時,只觸發(fā)一次,自己可以用bindSetter方法來做測試。當(dāng)不想綁定時可以用myc.unwatch()方法來解除綁定。

2.使用bindSetter()。
bindSetter(setter:Function, host:Object, chain:Object,commitOnly:Boolean = false):ChangeWatcher,例如:
var myc:ChangeWatcher=BindingUtils.bindSetter(change,text1,"text",true);
private function change(str:String):void
{
text2.text=str;
}
change就是當(dāng)綁定源發(fā)生變化時所觸發(fā)的函數(shù),其他參數(shù)都一樣。
3.使用ChangeWatcher.watch()。
同樣可以用ChangeWatcher.watch方法來監(jiān)控對象屬性的變化,非常有用。
watch(host:Object, chain:Object,handler:Function,commitOnly:Boolean = false):ChangeWatcher,例如:
var myc:ChangeWatcher=ChangeWatcher.watch(text1,"text",change);
private function change(e:Event):void
{
text2.text=text1.text;
}
這里的Event和綁定數(shù)據(jù)所定義的觸發(fā)事件有關(guān),你可以用所有事件的父類Event來表示。

注意:
as主要是通過mx.binding.utils.BindingUtils 這個類來實現(xiàn)數(shù)據(jù)綁定,用MXML和as實現(xiàn)數(shù)據(jù)綁定有以下幾點不同:
1.當(dāng)使用AS做數(shù)據(jù)綁定時,bindProperty()或 bindSetter()方法中不能使用AS代碼,這和MXML是不同的, 可以用bindSetter() 方法來申明一個綁定處理函數(shù)。
2.當(dāng)使用AS做數(shù)據(jù)綁定時,同樣不能使用EX4語法,也就是說不能直接使用XML解析語法了。
3.當(dāng)使用AS做數(shù)據(jù)綁定時,在屬性鏈中不能使用任何函數(shù)和數(shù)組。
4.MXML具有更好的錯誤提示和警告功能。
最后來講講屬性鏈。
屬性鏈就是bindProperty()和 bindSettet()等方法中的chain參數(shù)所表示的對象, 有時也許綁定源并不只是text1.text這樣的簡單形式,也可以是類似于user.name.text1.text,那么就存在一個關(guān)系鏈的問題,如果這條鏈中的某一項發(fā)生了改變,會不會觸發(fā)綁定呢?答案是如果你想讓其改變其中的某一項都能觸發(fā)數(shù)據(jù)綁定,那么這條鏈的每個元素必須是可綁定的。對于上面的這種形式,可以這樣使用bindProperty方法:
bindProperty(text2, "text", this, ["user", "name","text1","text"])。

相關(guān)文章

最新評論