下面是一个非常简单的示例,随机,如果我单击step2按钮,状态将会改变,但第2步面板将不会出现。
我怀疑该州的孩子由于某种原因没有被创建,这就是为什么我将itemCreationPolicy设置为“立即”,但它没有区别
这对应用程序来说是灾难性的,因为用户处于不稳定状态并被迫刷新
请问任何想法?
<s:BorderContainer xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx"
creationPolicy="all" currentState="step1">
<s:states>
<s:State name="step1"/>
<s:State name="step2"/>
</s:states>
<s:BorderContainer includeIn="step1" itemCreationPolicy="immediate">
<s:Panel title="Step 1"/>
</s:BorderContainer>
<s:BorderContainer includeIn="step2" itemCreationPolicy="immediate">
<s:Panel title="Step 2"/>
</s:BorderContainer>
<s:Button title="step1" click="{this.setCurrentState('step1',true)}"/>
<s:Button title="step2" click="{this.setCurrentState('step2',true)}"/>
</s:BorderContainer>
答案 0 :(得分:1)
我刚刚使用Flex SDK 4.1测试它,它可以在不更改创建策略的情况下运行。单击“步骤2”会成功更改状态。
BTW:你不需要点击事件处理程序中的花括号......
<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx" currentState="step1">
<s:layout>
<s:VerticalLayout/>
</s:layout>
<s:states>
<s:State name="step1"/>
<s:State name="step2"/>
</s:states>
<s:BorderContainer includeIn="step1">
<s:Panel title="Step 1"/>
</s:BorderContainer>
<s:BorderContainer includeIn="step2">
<s:Panel title="Step 2"/>
</s:BorderContainer>
<s:Button label="step1" click="setCurrentState('step1', true)"/>
<s:Button label="step2" click="setCurrentState('step2', true)"/>
</s:Application>
答案 1 :(得分:1)
似乎您使用的是旧版/预发行版的Flex 4 SDK。更新到4.1.0 - 最后一个稳定版本可能是个好主意。
P.S:写作this.setCurrentState('step1',true)
不是最好的主意。我建议使用currentState = 'step1'
- 这是国家改变的官方方式。