首页 > 网站 > WEB开发 > 正文

14.7.创建个性化可绑定的属性

2024-04-27 13:52:18
字体:
来源:转载
供稿:网友
14.7.1 问题
我想创建一个基于某种特殊的而非依赖于propertyChange 事件的数据绑定。
14.7.2. 解决办法
设置[Bindable]标签的event 属性,使用一个字符串做为类型的参数来进行事件的分发。
14.7.3. 讨论
Flex 框架中的数据绑定的基础其实是一个基于事件的系统。默认的数据绑定的事件类型是分发到propertyChange 事件。在框架内部,对于目标属性数据的更新并不一定是直接由数据绑定的源直接分发过去的。你可以在一个数据绑定语句中自定义一个事件类型,通过使用[Bindable]标签的event 属性。例如:
+展开
-ActionScript
[Bindable(event="myValueChanged")]

当你覆盖了默认的[Bindable]标签的event 属性的定义,你必须分布指定的事件来使数据绑定生效。

接下来的例子使用了自定义的绑定事件来更新目标属性的值。
+展开
-XML
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxmllayout="vertical">
<mx:Script>
<![CDATA[
private var _firstName:String;
private var _lastName:String;
public static const FIRST_NAME_CHANGED:String = "firstNameChanged";
public static const LAST_NAME_CHANGED:String = "lastNameChanged";
private function clickHandler():void
{
firstName = fnInput.text;
lastName = lnInput.text;
}
[Bindable(event="firstNameChanged")]
public function get firstName():String
{
return _firstName;
}
public function set firstName( str:String ):void
{
_firstName = str;
dispatchEvent( new Event( FIRST_NAME_CHANGED ) );
}
[Bindable(event="lastNameChanged")]
public function get lastName():String
{
return _lastName;
}
public function set lastName( str:String ):void
{
_lastName = str;
dispatchEvent( new Event( LAST_NAME_CHANGED ) );
}

]]>
</mx:Script>
<mx:Panel title="User Entry."
paddingLeft="5paddingRight="5"
paddingTop="5paddingBottom="5">

<mx:HBox>
<mx:Label text="First Name:" />
<mx:TextInput id="fnInput" />
</mx:HBox>
<mx:HBox>
<mx:Label text="Last Name:" />
<mx:TextInput id="lnInput" />
</mx:HBox>
<mx:Button label="submitclick="clickHandler();" />
<mx:HRule width="100%" />
<mx:Label text="You Entered:fontWeight="bold" />
<mx:HBox>
<mx:Label text="First Name:" />
<mx:Text text="{firstName}" />
</mx:HBox>
<mx:HBox>
<mx:Label text="Last Name:" />
<mx:Text text="{lastName}" />
</mx:HBox>
</mx:Panel>
</mx:Application>
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表