成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

技術分享 在ActionScript中如何定義Flex數據綁定

開發 后端
本文向大家介紹一下在ActionScript 中定義Flex數據綁定的方法,通過使用mx.binding.utils.BindingUtils能夠在ActionScript中定義綁定。

你對在ActionScript 中定義Flex數據綁定是否了解,這里和大家分享一下,通過使用bindProperty() 方法可以讓我們創建一個到用變量實現的屬性的數據綁定,或者用bindSetter()方法創建一個到用方法實現的屬性的Flex數據綁定。

在ActionScript 中定義Flex數據綁定

通過使用mx.binding.utils.BindingUtils能夠在ActionScript中定義綁定。這個類定義了幾個靜態方法,通過使用bindProperty() 方法可以讓我們創建一個到用變量實現的屬性的數據綁定,或者用bindSetter()方法創建一個到用方法實現的屬性的Flex數據綁定。

(1)在MXML 與在ActionScript 定義Flex數據綁定的區別

編譯期在MXML 中定義Flex數據綁定與在運行期在ActionScript 中定義Flex數據綁定有一些不同之處:
◆不能在由bindProperty()或者bindSetter()方法定義綁定表達式中引入ActionScript 代碼。相反,使用bindSetter()方法可以指定一個在綁定發生時調用的
方法。
◆ 不能在由ActionScript 中定義的綁定表達式中引入E4X 表達式。
◆ 在由the bindProperty()或者bindSetter()方法定義的Flex數據綁定表達式的屬性鏈中不能引入函數或者數組元素。更多信息見Working with bindable property chains.
◆同運行時使用bindProperty()或者bindSetter()定義的Flex數據綁定相比,MXML 編譯器有更好的警告和錯誤檢查支持。

(2)范例:在ActionScript 中定義Flex數據綁定

下面的例子是用bindSetter()建立了一個Flex數據綁定。bindSetter()方法的參數設置如下:
◆ 源(source) 對象
◆ 源(source) 屬性名
◆ 當源(source)屬性變化被調用的方法。
下面的范例中,當向TextInput 控件中輸入文本時,文本會被轉換為大寫形式并拷貝給TextArea
控件:
 

  1. <?xml version="1.0"?> 
  2. <!-- binding/BindSetterAS.mxml --> 
  3. <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"> 
  4. <mx:Script> 
  5. <![CDATA[  
  6. import mx.binding.utils.*;  
  7. import mx.events.FlexEvent;  
  8. // Method called when myTI.text changes.  
  9. public function updateMyString(val:String):void {  
  10. myTA.text = val.toUpperCase();  
  11. }  
  12. <!-- Event listener to configure binding. -->  
  13. public function mySetterBinding(event:FlexEvent):void {  
  14. var watcherSetter:ChangeWatcher =  
  15. BindingUtils.bindSetter(updateMyString, myTI, "text");  
  16. }  
  17. ]]> 
  18. </mx:Script> 
  19. <mx:Label text="Bind Setter using setter method"/> 
  20. <mx:TextInput id="myTI" 
  21. text="Hello Setter" /> 
  22. <mx:TextArea id="myTA" 
  23. initialize="mySetterBinding(event);"/> 
  24. </mx:Application> 

 (3)定義綁定觀察者 (watchers)

Flex 有個mx.binding.utils.ChangeWatcher 類,可以用這個類來定義一個Flex數據綁定觀察者。通常,Flex數據綁定觀察者在綁定發生時激活一個事件監聽器。可按照下面的范例使用
ChangeWatcher 的watch()即可建立一個Flex數據綁定觀察者:
 

  1. <?xml version="1.0"?> 
  2. <!-- binding/DetectWatcher.mxml --> 
  3. <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" 
  4. initialize="initWatcher();"> 
  5. <mx:Script> 
  6. <![CDATA[  
  7. import mx.binding.utils.*;  
  8. import mx.events.FlexEvent;  
  9. import mx.events.PropertyChangeEvent;  
  10. public var myWatcher:ChangeWatcher;  
  11. // Define binding watcher.  
  12. public function initWatcher():void {  
  13. // Define a watcher for the text binding.  
  14. ChangeWatcher.watch(textarea, "text", watcherListener);  
  15. }  
  16. // Event listener when binding occurs.  
  17. public function watcherListener(event:Event):void {  
  18. myTA1.text="binding occurred";  
  19. // Use myWatcher.unwatch() to remove the watcher.  
  20. }  
  21. ]]> 
  22. </mx:Script> 
  23. <!-- Define a binding expression_r to watch. --> 
  24. <mx:TextInput id="textinput" text="Hello"/> 
  25. <mx:TextArea id="textarea" text="{textinput.text}"/> 
  26. <!-- Trigger a binding. --> 
  27. <mx:Button label="Submit" click="textinput.text='Goodbye';"/> 
  28. <mx:TextArea id="myTA1"/> 
  29. </mx:Application> 

上面的范例中,為Flex數據綁定觀察者定義了事件監聽器,在這個事件監聽器中使用了單個參數來包含事件對象。事件對象的數據類型由被觀察的屬性所決定。每個可綁定的屬性會不同的
事件類型以及相關的事件對象。有關確定事件類型的更多信息見“使用Bindable 元數據標記”。
 

【編輯推薦】

  1. Adobe Flex提供三種方法指定Flex數據綁定
  2. 術語匯編 Flex數據綁定概述
  3. Flex數據綁定的四種方式
  4. 解析Flex全屏模式設置方法
  5. Flex內存泄露解決方法和內存釋放優化原則

 

 

責任編輯:佚名 來源: myspace.com
相關推薦

2010-08-11 15:51:45

Flex DataGr

2010-08-09 15:41:13

Flex字體

2010-07-28 12:41:18

Flex組件

2010-07-30 10:53:53

Flex數據綁定

2010-08-09 10:39:14

FlexACtionSCrip

2010-08-12 11:05:33

Flex數據綁定

2010-07-28 13:31:10

Flex數據綁定

2010-07-28 13:11:13

Flex數據綁定

2010-08-02 16:33:11

Flex Spring

2010-08-05 13:07:11

FlexJson

2010-08-11 14:47:54

Flex樣式

2010-07-30 10:45:08

Flex數據綁定

2010-07-30 09:08:21

Flex數據綁定

2010-08-12 11:34:15

Flex數據綁定

2010-08-05 15:06:19

Flex數據綁定

2010-08-10 14:08:09

Flex嵌入字體

2010-08-09 15:30:00

Flex字體

2010-07-30 09:28:09

Flex數據綁定

2010-07-28 13:24:20

Flex數據綁定

2010-08-12 10:56:17

Flex數據綁定
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲黄色视屏 | 欧美中文字幕一区二区三区亚洲 | 精品久久九九 | 日韩精品视频在线播放 | 亚洲一区二区三区在线播放 | 五月槐花香 | 蜜桃精品在线 | 国产一区二区三区 | 九九色九九 | 国产精品美女久久久久久不卡 | 亚洲一区二区三区在线 | 亚洲精品在线免费观看视频 | 欧美一区成人 | 羞羞视频一区二区 | 美日韩免费视频 | 久久国产视频播放 | 成人性视频免费网站 | 成人一级黄色毛片 | a毛片 | 女同久久另类99精品国产 | 久久精品国产一区二区三区 | 羞羞视频免费观看 | 成人精品在线观看 | 久久神马 | 精品国产乱码久久久久久丨区2区 | www.久久.com | 色黄网站 | 天堂成人国产精品一区 | 天天干狠狠操 | 久久国产日韩 | 国产黄色av网站 | 婷婷丁香激情 | 夜夜草导航| 国产精品成人一区二区三区 | 亚洲精品日日夜夜 | 天天色综网 | 日韩欧美高清 | 亚洲欧美日韩国产综合 | 国产线视频精品免费观看视频 | 亚洲精品一区av在线播放 | 精品欧美一区二区三区久久久 |