日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Flex3双向绑定完善版

發(fā)布時間:2025/3/19 编程问答 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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();}}}

    ?

    ?

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

    ?

    也提供了解除綁定的方法

    ?

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

    轉載于:https://blog.51cto.com/xiweicheng/677617

    總結

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

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