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

开发 后端
Flex有很多值得学习的地方,本文向大家介绍一下Flex[Bindable]的概念及使用方法,Flex[Bindable]大概又是Flex用得最多的元数据了。

在学习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<content.length;i++)  
  19. {  
  20. _w+=content[i]+"\r\n";  
  21. }  
  22. return_w;  
  23. }  
  24. }  
  25.  

 ◆原来的设想是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.  
  8. InsteadwhenyouputFlex[Bindable]onaget/setproperty,  
  9.  
  10. thecompilermakesitbindablewithalittlecreativerewritingthatallowstheframeworktowatchthegetfunction,  
  11. anddispatchachangeeventwhenthegetfunctionistriggered.Thismeansthatautomaticbindablepropertiesdon’  
  12. tworkwhenthegetfunctioniscomputedfrommultiplevalues,  
  13. orwhenyouchangeitsvaluebysettingabackingfield,ratherthanusingthesetfunction.  
  14.  
  15. It_also_meansthatifyouhavenosetfunction,  
  16.  
  17. wecanprettymuchguaranteethatthere’snowayautomaticallybindablegetpropertieswillbetriggered.areadonlypropeertyis,  
  18. tothecompiler,completelyopaque…atthemoment,ithasnoideawherethatvalueiscomingfrom,  
  19. 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<content.length;i++)  
  20. {  
  21. _w+=content[i]+"\r\n";  
  22. }  
  23. return_w;  
  24. }  
  25. }  
  26.  

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

【编辑推荐】

  1. Flex页面跳转实现的几种方式
  2. FlexBuilder4十大新特性闪亮登场
  3. Flex框架中Cairngorm和Mate的优点大比拼
  4. FlexBuilder3.0与Eclipse3.4的完美结合
  5. 解析Flex应用开发步骤 新特性和技术框架 
责任编辑:佚名 来源: 163.com
相关推荐

2010-09-07 14:21:22

PPPoE协议

2022-04-12 08:30:45

TomcatWeb 应用Servlet

2011-03-23 11:01:55

LAMP 架构

2009-09-09 09:26:00

2010-03-08 14:53:48

Linux分区

2011-09-01 13:51:52

JavaScript

2023-02-01 08:13:30

Redis内存碎片

2010-01-26 09:31:31

千兆接入交换机

2009-12-14 14:50:46

Ruby传参数

2009-06-10 18:12:38

Equinox动态化OSGi动态化

2021-10-29 16:36:53

AMSAndroidActivityMan

2022-08-30 07:00:18

执行引擎Hotspot虚拟机

2009-12-16 16:39:01

Visual Stud

2010-01-05 15:32:48

交换机技术

2009-12-22 15:39:36

IPPBX技术

2009-12-08 18:02:06

PHP final关键

2017-08-18 14:01:44

大数据dataWrangle

2018-10-25 15:24:10

ThreadLocal内存泄漏Java

2013-11-14 17:02:41

Android多窗口

2021-04-13 12:55:06

SpringMVC解析器接口
点赞
收藏

51CTO技术栈公众号