深入分析Flex[Bindable]及使用方法

在学习Flex的过程中,你可能会遇到Flex[Bindable]方面的问题,这里和大家分享一下,希望本文的介绍能让你有所收获。

深入分析Flex[Bindable]及使用方法

◆Flex[Bindable]大概又是Flex用得最多的元数据了。刚开始用用确实好简单,效率真是没的说。不过这几天用着却碰到了些问题,我自己搜集了些资料,想着有必要在blog里总结一下吧。
啥是元数据(metadata)

今天不晓得为什么livedoc.adobe.com这么慢,没办法,拿不到权威的解释了。我就按自己的理解随便解释一下:首先要明白元数据不是语法的一部分,而是专门给编译器用的,说白了是告诉编译器做某些事情,学过java之类的应该知道。那Bindable来讲,它的作用是告诉flex编译器,给某些某些东西建立绑定关系,flex编译器会在编译过程中给AS(flex编译器就是把mxml编译成as,再编译到swf,也可能直接编译倒swf,我这里假设有as这么个环节)加一点事件发生和处理之类的代码,由此绑定的关系便建立了,如果我们用纯粹as3代码来写也是可以实现的,就是太太太麻烦。

举个例子:给下面的public变量加上Flex[Bindable]

 
 
 
  1. Flex[Bindable]
  2. publicvarname:String="";

◆作为一个public变量,肯定既可以被赋值,也能赋值给别的变量。绑定的作用就是,当name改变的时候(被赋值了),可能通知其它被name影响(赋值给它们)的变量发生改变。这里的“可能”就需要编译器来判断,这就是为什么元数据是给编译器用的原因了。在mxml里用{}的语法的地方就是绑定的对象,比如label={xxx.name},当name变化,label也跟着变化。这样,我们只是很简单的改变了name的值,由于有绑定,界面上的label也跟着自动变化了,爽吧。
能用在哪里

三个地方:类,变量,getter/setter。是不是public没有关系,private的就只能给自家用呗。用在Class上就是简单的给所有的public属性(包括变量,getter/setter,普通方法)加上Flex[Bindable],可是一般的方法不能用Flex[Bindable]呀,于是一般就能看到flex给了个warning,直接无视:)。变量嘛就是上面讲的,很简单略掉。
用在只读,只写属性(getter/setter)上面

终于讲到关键地方了,因为getter和setter很像方法,用起来会有点不同。看看这个例子:

 
 
 
  1. Flex[Bindable]
  2. privatevarcontent:Array=newArray();
  3. Flex[Bindable]
  4. publicfunctionset_content(ct:String):void
  5. {
  6. content=ct.split(SEP);
  7. }
  8. Flex[Bindable]
  9. publicfunctionget_wholeText():String
  10. {
  11. if(content.length==0)
  12. {
  13. return"";
  14. }
  15. else
  16. {
  17. var_w:String="";
  18. for(vari:int=0;i
  19. {
  20. _w+=content[i]+"\r\n";
  21. }
  22. return_w;
  23. }
  24. }

 ◆原来的设想是content绑定_wholeText,可它是不工作的。为什么?_wholeText太复杂了,被编译器排除在“可能”之外,编译器认为没有绑定关系,如果只是简单的returncontent,倒是可以的。我这里搜到了一些比较权威的解释。来自http://www.rubenswieringa.com/blog/binding-read-only-accessors-in-flex找到ElyGreenfield讲的。

 
 
 
  1. Nowkeepinmindthatthere’snowayforthecompilertoactuallytellifthevalueofapropertygetfunctionwouldbedifferentifcalled,
  2. shortofdoinganextensivecodeflowanalysisofthegetfunction,
  3. identifyingalltheinputsthatmightbeaffectingthevalueofthegetfunction
  4. (i.e.,memberfields,statics,globalsthatareusedinthegetfunctionandinanymethods,globalfunctions,closures,etc)itmightcall,
  5. andsettingupwatchersoneveryoneofthosetotriggerthebindingwhenanyofthemchange.
  6. That’sprohibitivelydifficult,andexpensivetodo.Sothecompilerdoesn’ttry.
  7. InsteadwhenyouputFlex[Bindable]onaget/setproperty,
  8. thecompilermakesitbindablewithalittlecreativerewritingthatallowstheframeworktowatchthegetfunction,
  9. anddispatchachangeeventwhenthegetfunctionistriggered.Thismeansthatautomaticbindablepropertiesdon’
  10. tworkwhenthegetfunctioniscomputedfrommultiplevalues,
  11. orwhenyouchangeitsvaluebysettingabackingfield,ratherthanusingthesetfunction.
  12. It_also_meansthatifyouhavenosetfunction,
  13. wecanprettymuchguaranteethatthere’snowayautomaticallybindablegetpropertieswillbetriggered.areadonlypropeertyis,
  14. tothecompiler,completelyopaque…atthemoment,ithasnoideawherethatvalueiscomingfrom,
  15. andhencewillneverbeableto‘automatically’triggerthebinding.

说白了就是为了降低复杂度和提高效率,复杂情况的getter会被忽略。如何解决?可以手动建立绑定,即[Bindable("eventName")]。把代码改成这样:

 
 
 
  1. Flex[Bindable]
  2. privatevarcontent:Array=newArray();
  3. Flex[Bindable]
  4. publicfunctionset_content(ct:String):void
  5. {
  6. content=ct.split(SEP);
  7. this.dispatchEvent(newEvent("_contectChanged"));
  8. }
  9. [Bindable("_contectChanged")]
  10. publicfunctionget_wholeText():String
  11. {
  12. if(content.length==0)
  13. {
  14. return"";
  15. }
  16. else
  17. {
  18. var_w:String="";
  19. for(vari:int=0;i
  20. {
  21. _w+=content[i]+"\r\n";
  22. }
  23. return_w;
  24. }
  25. }

 这样就避免了编译器去自动识别。自己加上绑定关系,当_content被赋值,发出_contentChanged事件,通知所有被绑定的getter方法执行一遍。这也说明了,绑定不过是事件游戏而已,flex为用户隐藏了很多底层算法。

分享名称:深入分析Flex[Bindable]及使用方法
网站URL:http://www.csdahua.cn/qtweb/news7/383057.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网