接下来的例子演示了Flex中通过监听ObjectProxy的propertyChange事件,检测一个Object是否变化。
让我们先来看一下Demo(
可以右键View Source或点击这里察看源代码):
下面是完整代码(或点击这里察看):
- <?xml version="1.0" encoding="utf-8"?>
- <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"
- layout="vertical"
- verticalAlign="middle"
- backgroundColor="white"
- creationComplete="init();">
-
- <mx:Script>
- <![CDATA[
- import mx.events.PropertyChangeEvent;
- import mx.utils.ObjectProxy;
-
- private var object:Object = {};
- private var objectProxy:ObjectProxy;
-
- private function init():void {
- objectProxy = new ObjectProxy(object);
- objectProxy.addEventListener(PropertyChangeEvent.PROPERTY_CHANGE, updateChange);
- objectProxy.name = "My Object";
- objectProxy.id = 31;
-
- /* Note: Any assignments made directly to the "object"
- Object do not dispatch the propertyChange event. */
- object.isDebug = false;
- object.id = 33;
-
- /* Note: Even though the earlier assignment to the "id"
- property didn't dispatch the propertyChange event,
- the "oldValue" property is still displayed as 33. */
- objectProxy.id = 45;
- }
-
- private function updateChange(evt:PropertyChangeEvent):void {
- arrColl.addItem(evt);
- }
- ]]>
- </mx:Script>
-
- <mx:ArrayCollection id="arrColl" />
-
- <mx:DataGrid dataProvider="{arrColl}"
- sortableColumns="false"
- draggableColumns="false"
- width="100%"
- height="100%">
- <mx:columns>
- <mx:DataGridColumn dataField="type" />
- <mx:DataGridColumn dataField="property" />
- <mx:DataGridColumn dataField="newValue" />
- <mx:DataGridColumn dataField="oldValue" />
- <mx:DataGridColumn dataField="source" />
- </mx:columns>
- </mx:DataGrid>
-
- </mx:Application>
代码:Peter deHaan 翻译/整理/编译:中文Flex例子
分享到:
相关推荐
Flex Data Binding是Adobe Flex框架中的核心特性之一,它允许开发者创建数据驱动的应用程序,通过将UI组件的属性与数据模型的属性直接关联,实现实时的数据同步。在Flex中,数据绑定确保当数据源发生变化时,相关的...
当我们使用`[Bindable]`元数据标签标记一个类的成员变量时,Flex编译器会自动为这个变量生成相关的访问器(getter和setter)。例如,在提供的代码段中,`list`变量被标记为`[Bindable]`: ```actionscript public ...
在Flex 3到Flex 4的进化中,生命周期有了显著的变化,这些变化旨在提高性能、可扩展性和稳定性。 Flex框架的生命周期包括了组件的初始化、布局、绘制、更新和销毁等关键阶段。理解这些阶段对于优化代码、提升应用...
在处理前端交互逻辑时,事件监听是一个非常核心的概念。在某些场景中,需要对输入框的值实时进行检查和响应,典型的例子包括即时搜索功能,用户在输入框中输入内容后,系统能够实时地根据输入内容给出搜索结果。这种...
https://github.com/mootools/mootools-core/issues/2170这个问题来自IE(LTE8)中对checkbox和radio change事件的实现问题,在IE(LTE8)中测试下来,当你点击一个checkbox或者radio,它的change事件是不会立即触发,...
Flex Data Grid是Adobe Flex框架中的一个组件,全称为MX:DataGrid或Spark:DataGrid。它用于展示和操作表格形式的数据,支持多种功能,如列排序、选择行、自定义渲染等。在Flex 4之后,分为MX和Spark两个版本,MX ...
主要介绍了js与jquery实时监听输入框值的oninput与onpropertychange方法,实例分析了oninput与onpropertychange实现下拉框里自动匹配关键字实时监听文本框value值变化的功能,需要的朋友可以参考下
通过以上步骤,你可以构建一个简单的气象观测系统,其中各个组件可以通过JavaBeans事件机制进行通信。实验报告应详细记录每个步骤的过程,包括代码实现、运行结果以及对观察者模式和JavaBeans事件理解的总结。 在...
自定义组件是Flex4开发中的一个重要方面,它不仅可以让开发者根据项目需求创建独特的UI元素,还可以极大地提高应用的表现力和用户体验。通过深入理解Spark架构以及组件的生命周期,开发者可以更高效地开发高质量的...
然而,上述代码中存在一个问题。当页面动态添加新的`<input>`元素时,由于`bind()`函数只对当前存在的元素生效,新添加的元素不会被监听到。为了解决这个问题,可以使用jQuery的`live()`函数。`live()`函数能为将来...
挺炫的一个效果,百度和谷歌好像已实现好多年了,我以为...通过监听input和propertychange事件实现实时的改动监听,input是主流,propertychange是ie,你懂的;通过ajax实现post动作,把返回内容显示成类似选框的形式;
默认情况下,当[Bindable]变量变化时,会触发“propertyChange”事件,而Flex会自动监听这个事件并更新UI。通常情况下,只需要使用简写形式[Bindable]即可。 **注意事项** - 当[Bindable]用于函数时,只能在setter...
数据源变化通常会触发`propertyChange`事件,Flex框架会监听这些事件并更新绑定的目标。 6. **延迟绑定**(lazy binding): 当数据源在初始化时可能不存在或未准备好时,可以使用`defer`属性延迟绑定的执行。 7...
在 Web 开发中,实时监听输入框值的变化是一个常见的需求,例如自动完成功能、实时搜索、表单验证等。在这个资源中,我们将介绍 JS 与 jQuery 实时监听输入框值的 oninput 与 onpropertychange 方法,并通过实例分析...
在本文中,我们将深入探讨Flex中的数据绑定机制,这是Flex应用中一个至关重要的概念。 数据绑定是Flex中的一种强大特性,它使得UI组件的属性可以直接与应用程序的数据模型进行连接。这意味着,当数据模型发生改变时...
`Bindable`是Flex中最常用的元数据标签之一,它用于通知Flex框架当属性发生变化时自动派发一个`propertyChange`事件。 - **无参数的Bindable** 当没有参数传递给`Bindable`时,表示当对应的属性值改变时会默认...
通过设置一个定时器(如1秒),在定时器回调函数中检查输入框的当前长度与上一次的长度。如果长度发生变化,就执行查询操作。这种方法的优点是实现简单,但缺点是可能会频繁触发查询,增加服务器负担,且无法做到...
要使用`PropertyChangeSupport`,首先需要在你的类中创建一个`PropertyChangeSupport`实例,然后通过`addPropertyChangeListener`方法添加监听器,通过`removePropertyChangeListener`方法移除监听器。例如: ```...