日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

Flex3双向绑定完善版

發(fā)布時間:2025/3/19 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Flex3双向绑定完善版 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

最近做Flex項目,碰到了雙向綁定的問題,

查了下網(wǎng)上,有解決方法

?

簡單說就是 2個單項綁定 + 簡易的同步機制

?

看代碼:

Java代碼 ?
  • /**實現(xiàn)雙向綁定工具類*/??
  • ????public?class?BindingUtil{ ??
  • ???????? ??
  • ???????? ??
  • ????????/**綁定方法*/??
  • ????????public?static?function?bind(obj1:Object,prop1:String,obj2:Object,prop2:String):void{ ??
  • ???????????? ??
  • ????????????/**是否在改變標志,類似?數(shù)據(jù)同步機制*/??
  • ????????????var?flag:Boolean?=?false; ??
  • ???????????? ??
  • ????????????ChangeWatcher.watch(obj1,prop1,function(event:Event):void{ ??
  • ????????????????if(!flag){ ??
  • ????????????????????/**鎖定對象*/??
  • ????????????????????flag?=?true; ??
  • ????????????????????obj2[prop2]?=?obj1[prop1]; ??
  • ????????????????????/**解鎖對象*/??
  • ????????????????????flag?=?false; ??
  • ????????????????} ??
  • ????????????}); ??
  • ???????????? ??
  • ????????????ChangeWatcher.watch(obj2,prop2,function(event:Event):void{ ??
  • ????????????????if(!flag){ ??
  • ????????????????????/**鎖定對象*/??
  • ????????????????????flag?=?true; ??
  • ????????????????????obj1[prop1]?=?obj2[prop2]; ??
  • ????????????????????/**解鎖對象*/??
  • ????????????????????flag?=?false; ??
  • ????????????????} ??
  • ????????????}); ??
  • ????????} ??
  • ????}??
  • /**實現(xiàn)雙向綁定工具類*/public class BindingUtil{/**綁定方法*/public static function bind(obj1:Object,prop1:String,obj2:Object,prop2:String):void{/**是否在改變標志,類似 數(shù)據(jù)同步機制*/var flag:Boolean = false;ChangeWatcher.watch(obj1,prop1,function(event:Event):void{if(!flag){/**鎖定對象*/flag = true;obj2[prop2] = obj1[prop1];/**解鎖對象*/flag = false;}});ChangeWatcher.watch(obj2,prop2,function(event:Event):void{if(!flag){/**鎖定對象*/flag = true;obj1[prop1] = obj2[prop2];/**解鎖對象*/flag = false;}});}}

    ?

    可以看到

    ?

    使用了ChangeWatcher注冊了一個函數(shù),并且使用了閉包的特性

    使得 var flag:Boolean 變量可以 在匿名函數(shù)中使用

    ?

    其實 flag的作用就是 類似 java的synchronized

    ?

    放置時間爭搶改變屬性的作用

    ?

    ?

    但是如果像這樣寫,那么不是很理想

    ?

    我改了一下:

    Java代碼 ?
  • /**實現(xiàn)雙向綁定工具類*/??
  • ????public?class?BindingUtil{ ??
  • ???????? ??
  • ????????public?var?watchers:ArrayCollection?=?new?ArrayCollection(); ??
  • ???????? ??
  • ????????/**綁定方法*/??
  • ????????public?function?bind( ??
  • ????????????obj1:Object,prop1:String, ??
  • ????????????obj2:Object,prop2:String):void{ ??
  • ???????????? ??
  • ????????????/**是否在改變標志,類似?數(shù)據(jù)同步機制*/??
  • ????????????var?flag:Boolean?=?false; ??
  • ???????????? ??
  • ????????????var?tempwatcher1:ChangeWatcher?=?ChangeWatcher.watch(obj1,prop1,function(event:Event):void{ ??
  • ????????????????if(!flag){ ??
  • ????????????????????/**鎖定對象*/??
  • ????????????????????flag?=?true; ??
  • ????????????????????obj2[prop2]?=?obj1[prop1]; ??
  • ????????????????????/**解鎖對象*/??
  • ????????????????????flag?=?false; ??
  • ????????????????} ??
  • ????????????}); ??
  • ???????????? ??
  • ????????????var?tempwatcher2:ChangeWatcher?=?ChangeWatcher.watch(obj2,prop2,function(event:Event):void{ ??
  • ????????????????if(!flag){ ??
  • ????????????????????/**鎖定對象*/??
  • ????????????????????flag?=?true; ??
  • ????????????????????obj1[prop1]?=?obj2[prop2]; ??
  • ????????????????????/**解鎖對象*/??
  • ????????????????????flag?=?false; ??
  • ????????????????} ??
  • ????????????}); ??
  • ???????????? ??
  • ????????????this.watchers.addItem(tempwatcher1); ??
  • ????????????this.watchers.addItem(tempwatcher2); ??
  • ????????} ??
  • ???????? ??
  • ????????/**解除綁定*/??
  • ????????public?function?unbind():void{ ??
  • ????????????for(var?i:int?=?0;?i<this.watchers.length;?i++){ ??
  • ????????????????ChangeWatcher(this.watchers.getItemAt(i)).unwatch(); ??
  • ????????????} ??
  • ????????} ??
  • ????}??
  • /**實現(xiàn)雙向綁定工具類*/public class BindingUtil{public var watchers:ArrayCollection = new ArrayCollection();/**綁定方法*/public function bind(obj1:Object,prop1:String,obj2:Object,prop2:String):void{/**是否在改變標志,類似 數(shù)據(jù)同步機制*/var flag:Boolean = false;var tempwatcher1:ChangeWatcher = ChangeWatcher.watch(obj1,prop1,function(event:Event):void{if(!flag){/**鎖定對象*/flag = true;obj2[prop2] = obj1[prop1];/**解鎖對象*/flag = false;}});var tempwatcher2:ChangeWatcher = ChangeWatcher.watch(obj2,prop2,function(event:Event):void{if(!flag){/**鎖定對象*/flag = true;obj1[prop1] = obj2[prop2];/**解鎖對象*/flag = false;}});this.watchers.addItem(tempwatcher1);this.watchers.addItem(tempwatcher2);}/**解除綁定*/public function unbind():void{for(var i:int = 0; i<this.watchers.length; i++){ChangeWatcher(this.watchers.getItemAt(i)).unwatch();}}}

    ?

    ?

    加入了屬性,保存了所有的綁定,

    ?

    也提供了解除綁定的方法

    ?

    這樣的好處,不言而喻吧,當你同個視圖想綁定不同對象的時候,那么就派上用場了!

    轉(zhuǎn)載于:https://blog.51cto.com/xiweicheng/677617

    總結(jié)

    以上是生活随笔為你收集整理的Flex3双向绑定完善版的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。