<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    樂在其中

    以JEE為主攻,以Flex為點綴,以Eclipse RCP為樂趣
    請訪問http://www.inframesh.org

    首頁 新隨筆 聯系 管理
      43 Posts :: 0 Stories :: 8 Comments :: 0 Trackbacks

    參考:ADOBE FLEX 3 DEVELOPER GUIDE

    1.什么是數據綁定?

       Data binding is the process of tying the data in one object to another object.

       數據綁定是一個對象的數據捆綁到另一個對象上的進程。

    2.數據綁定的作用

       It provides a convenient way to pass data between the different layers of the application.

       數據綁定提供了一個在程序的各個層面之間傳遞數據的便利方法

    3.數據綁定的機制

       Data binding requires a source property, a destination property, and a triggering
    event that indicates when to copy the data from the source to the destination. An
    object dispatches the triggering event when the source property changes.

       數據綁定要求一個源屬性,一個目的屬性和一個觸發事件。這個觸發事件指示從源屬性復制數據到目的屬性上。當源屬性改變時一個對象派發這個觸發事件。

    4.數據綁定的定義方式

       1)句法:大括號{} 

       2)MXML標簽:<mx:Binding>

       3)AS類: mx.binding.utils.BindingUtils

    5.數據綁定的發生時機

       1) The binding source dispatches an event because the source has been modified.

           綁定源改變后派發事件

           This event can occur at any time during application execution.

            這個事件在程序運行的任何時間都可發生。

        2)At application startup when the source object dispatches the initialize event.

             程序啟動時源對象派發初始化事件

             All data bindings are triggered once at application startup to initialize the 

             所有的數據綁定在程序啟動初始化目的屬性時都會被觸發一次。

    6.綁定屬性

    1)Using data binding with data models

           綁定數據model

       2)  Binding a source property to more than one destination property

            一對多綁定

       3)Binding more than one source property to a destination property

            多對一綁定

       4)Defining bidirectional bindings

            雙向綁定

            eg:

    7.綁定函數

    1)Using functions that take bindable properties as arguments

        2)  Binding to functions in response to a data-binding event

    8.綁定對象

    1)  Binding to Objects

         2)  Binding to properties of Objects

              綁定對象的屬性,可使用元素標簽[Bindable]在對象所在的類的定義前。則這個對象的所有

    公有屬性都被綁定。

    9.綁定數組

    1)  Binding to arrays

         2)  Binding to array elements

    10.綁定元素標簽

    句法:[Bindable] 或 [Bindable(event="eventname")]

    [Bindable]是[Bindable(event="propertyChange")]的簡寫。當被綁定的屬性發生改變時,Flex

    會派發事件觸發綁定。

    主要有三種使用情況:

    1) 在屬性定義前 2) 類定義前 3)getter 或 setter 方法前

     

    可以使用MX標簽綁定,也可以使用BindUtil來進行綁定,下面是我做的一個例子,實現BO與頁面空間的自動雙向綁定:

    BO定義:

    package com.bankcomm.icms.domain.migrate
    {
        [Bindable]
        public class Bo {
            private var _property0:String = "";
            private var _property1:int = 0;
            private var _property2:String = "";
            
            public var className:String = "Bo";
            public var propertyNames:Array = ["property0", "property1", "property2"];
            public function Bo() {}
            
     
            public function set property0(value:String):void{
                this._property0 = value;
            }
     
            public function get property0():String{
                return this._property0;
            }
     
            public function set property1(value:int):void{
                this._property1 = value;
            }
            
            public function get property1():int{
                return this._property1;
            }
     
            public function set property2(value:String):void{
                this._property2 = value;
            }
            
            public function get property2():String{
                return this._property2;
            }        
        }
    }

    下面是應用代碼:

    <?xml version="1.0" encoding="utf-8"?>
    <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" creationComplete="init();">
        <mx:Script>
            <![CDATA[
                import com.bankcomm.icms.domain.migrate.Bo;
                import com.bankcomm.icms.common.DataDict;
                import mx.binding.utils.BindingUtils;
                import mx.collections.ArrayCollection;
                
                private var bo:Bo = new Bo();
                
                function init():void {
                    autowireBindObject(bo);
                }
                
                function autowireBindCollection(arr:ArrayCollection):void {
                    
                }
                
                function autowireBindObject(bo:Object) {
                    for each(var propertyName:String in bo.propertyNames) {
                        var elem:Object = this[bo.className + "_" + propertyName];
                        if(elem==null) continue;            
                        var value = bo[propertyName];
                        
                        if(elem instanceof ComboBox) {
                            ComboBox(elem).dataProvider = DataDict.dictYesNo;
                            BindingUtils.bindProperty(elem, "selectedIndex", bo, propertyName, false);
                            BindingUtils.bindProperty(bo, propertyName, ComboBox(elem), "selectedIndex",false);
                        } else if(elem instanceof TextInput) {
                            BindingUtils.bindProperty(elem, "text", bo, propertyName, false);
                            BindingUtils.bindProperty(bo, propertyName, TextInput(elem), "text", false);
                        } else if(elem instanceof DateField) {
                            BindingUtils.bindProperty(elem, "text", bo, propertyName, false);
                            BindingUtils.bindProperty(bo, propertyName, DateField(elem), "text", false);
                        } else {
                            
                        }
                    }
                }
                
                function chageModelAndUpdateUI() {
                    bo.property0 = "xxx";
                    bo.property1 = 1;
                    bo.property2 = "2009-02-10";
                }
                
                function chageUIAndUpdateModel():void {
                    var a = bo.property1;
                }
                
            ]]>
        </mx:Script>
        
        <mx:TextInput id="Bo_property0" x="65" y="10"/>
        <mx:ComboBox id="Bo_property1" x="65" y="51" width="160"/>
        <mx:DateField id="Bo_property2" x="65" y="92" width="160"/>
        
        <mx:Button x="65" y="133" label="模型改變更新UI" click="chageModelAndUpdateUI();" />
        
        <mx:Button x="179" y="133" label="UI改變更新模型" click="chageUIAndUpdateModel();" />
        
        
        
    </mx:Application>
    posted on 2009-02-10 16:11 suprasoft Inc,. 閱讀(4887) 評論(1)  編輯  收藏 所屬分類: RIA/Flex

    Feedback

    # re: Flex 綁定/雙向綁定 2014-08-15 09:16 劉備
    我要做的事情是用flex連接java,通過java讀取一個entity之后,綁定到flex的對象,并顯示出來。  回復  更多評論
      


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    ©2005-2008 Suprasoft Inc., All right reserved.
    主站蜘蛛池模板: 亚洲日韩精品国产一区二区三区| 亚洲国产精品久久久久久| 亚洲特级aaaaaa毛片| 在线看片免费人成视久网| 综合自拍亚洲综合图不卡区| 1000部拍拍拍18勿入免费凤凰福利 | 亚洲性线免费观看视频成熟| 亚洲另类激情综合偷自拍 | 6080午夜一级毛片免费看6080夜福利| 国产精品亚洲成在人线| 99在线热视频只有精品免费| 亚洲另类春色校园小说| 男女啪啪永久免费观看网站| 免费夜色污私人影院网站| 在线亚洲97se亚洲综合在线 | 久久精品a一国产成人免费网站| 亚洲色精品VR一区区三区| 国产精品色午夜免费视频| 一级特级女人18毛片免费视频| 亚洲中文字幕在线观看| 91热久久免费精品99| 亚洲 日韩 色 图网站| 亚洲AV无码之日韩精品| 中文字幕免费不卡二区| 亚洲av无码一区二区三区观看| 日本免费观看网站| 国产免费AV片在线观看播放| 久久精品亚洲中文字幕无码麻豆| 国内精品乱码卡1卡2卡3免费| 人人公开免费超级碰碰碰视频| 久久久亚洲欧洲日产国码二区| 免费无码又爽又刺激毛片| 91视频免费观看高清观看完整| 亚洲日本国产乱码va在线观看| 免费观看亚洲人成网站| 久爱免费观看在线网站| 欧洲亚洲综合一区二区三区| 久久亚洲国产精品五月天| 免费国产小视频在线观看| 91精品国产免费网站| 免费人成再在线观看网站 |