加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Flex数据绑定失效的问题

发布时间:2020-12-15 04:44:08 所属栏目:百科 来源:网络整理
导读:? 我在TabNavigator中的多个tab页内都做了组件间的属性绑定操作: mx:Image id="imgVideo" source="{videoClass}" visible="false" width="100%" height="100%" horizontalAlign="center" includeInLayout="{imgVideo.visible}"/ mx:Button width="30" enabl

?

我在TabNavigator中的多个tab页内都做了组件间的属性绑定操作:

<mx:Image id="imgVideo" source="{videoClass}" visible="false" width="100%" height="100%" horizontalAlign="center"
includeInLayout="{imgVideo.visible}"/>

<mx:Button width="30" enabled="{imgVideo.visible}" label="播放" paddingLeft="0" paddingRight="0"/>

?

?

protected function changeHandler(event:IndexChangedEvent):void

{

if (event.newIndex == 1 && this._question && this._question.soundSourceMode.filePath)

{

loadSoundFromFilePath(this._question.soundSourceMode.filePath);

}

else if (event.newIndex == 2 && this._question && this._question.videoSourceMode.filePath)

{

imgVideo.visible = true;

videoBtn.visible = false;

}

}

?

?

?

其它的tab页中都正常,唯有上面这段代码没起作用。

?

?

经过代码替换,删除调试等没有发现问题。但一篇博客让我明白了原由:

Flex 数据绑定易犯的错误:普遍的误用和错误

?

?

原来是组件初始化的问题, 我改变image的属性时该组件初始化还未完成,也就是说属性的改变并发生在属性绑定之后,而属性的绑定动作在初始化时是有异常的。当我通过as改变了组件的属性时,它并未起作用。 相反,我另一段代码(与上面非常类似),只是因为是在一段延迟之后才做了属性的变化,因此它起到了应有的作用。 从上面as代码中可以看出,我是在change事件中做的属性的改变。 但第一个改变发生在另外一个方法中,实际这个方法中有一段异步加载的代码,也就有了一些延时,所以它没问题。 但第二个是立即执行的。 我的子代加载策略是自动的,所以在方法事件处理时子组件并未初始化完毕,只是可以访问了。

?

我试了两种方法, 一是将子代加载策略设置为all,二是让属性的改变作一个延迟:

creationPolicy="all"

or

?

callLater(function():void

{

imgVideo.visible = true;

videoBtn.visible = false;

});

?

真是如博主所说: 若开发者不完全理解它的机制的话,可能会给程序造成初始化缓慢或失败的问题。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读