繁体   English   中英

如何在Flex应用程序中分解视图?

[英]How can I break down a view in a flex application?

我编写了一个flex(移动)应用程序,但最终结果超出了我的预期。

我对我的所有课程以及AS文件中的所有内容都感到非常满意。 但是,由于我使用MXML布局应用程序,因此视图的确很大。

我当时正在考虑创建外部组件,以使它更具可读性,但我不确定什么是最好的方法,或者不确定这样做是否是最好的方法。

例如,我认为av:Group具有以下内容:

<s:VGroup width="100%" height="80%" includeIn="normal" horizontalAlign="center" top="70" id="imageGroup">
    <s:Label id="lblFile" visible="false" width="98%" textAlign="center" includeInLayout="true" color="0xFFFFFF"/>
    <s:BorderContainer id="framingBorder" borderColor="0xFFFFFF" borderWeight="15" cornerRadius="7">
        <s:Image id="image" source="{IMAGE_SAMPLE}" horizontalCenter="0"/>

    </s:BorderContainer>    
    <s:BorderContainer id="shareBorder" borderColor="0xFFFFFF" borderWeight="5" height="30" cornerRadius="7" width="{framingBorder.width}" visible="false" buttonMode="true" click="copyToClipboard(lblURL.text)">
        <s:layout>
            <s:HorizontalLayout verticalAlign="middle" horizontalAlign="left" gap="3"/>
        </s:layout>
        <s:Label text="url:" styleName="copyURL" />
        <s:BorderContainer borderColor="0xCDCDCD" borderWeight="1" width="{lblURL.width + 5}" height="{lblURL.height + 5}">
            <s:layout>
                <s:HorizontalLayout verticalAlign="middle" horizontalAlign="center"/>
            </s:layout>
            <s:Label id="lblURL" text="" styleName="copyURL" />
        </s:BorderContainer>
        <s:Spacer width="100%" />
        <s:HGroup>
            <s:Label color="0xFF0000" text="copy" styleName="copyURL" />
            <s:Image source="/assets/icons/page_copy_small.png" horizontalCenter="0" horizontalAlign="right"/>
        </s:HGroup>
    </s:BorderContainer>    
</s:VGroup>

任何人都可以向我指出正确的方向,即如何将其从视图中移出以使其更整洁,以及如何仍然可以访问此代码块中的项目(即,我仍然希望能够从中修改lblURL我认为这是一个动态值)

提前致谢,

您处在正确的轨道上,艾米(Amy)发布的链接很好地说明了如何进行布局。 您可能也对cairngorm和parsely感兴趣 ,它们是更完整的解决方案的框架/工具。

但是目前,我认为将视图的各个部分分成多个组件是一个不错的开始。

您仍然可以在主应用程序中修改标签(例如):

<views:myBox id="box"  />
<s:Button click="{box.myLabel.text = 'changed'}" />

myBox.mxml:

<?xml version="1.0" encoding="utf-8"?>
<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" width="400" height="300">
    <s:Label id="myLabel" text="this is my label" />
</s:BorderContainer>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM