Flex中容器问题的动态minHeight

Posted

技术标签:

【中文标题】Flex中容器问题的动态minHeight【英文标题】:Dynamic minHeight of a container problems in Flex 【发布时间】:2012-08-18 03:00:06 【问题描述】:

我的 Flex 应用程序中容器的动态最小高度存在问题。

该应用程序由多个选项卡组成,每个选项卡都根据需要设置了自己的 minHeight 属性。但是,在一个选项卡中,我在两个视图之间切换 - 一个列表视图和一个详细视图。

主视图:

<mx:TabNavigator id="tabNavigator"   change="MainViewModel.getInstance().onTabClick(event);" resizeToContent="true">
        <s:NavigatorContent label="Welcome" minWidth="950"  minHeight="300" >
            <startview:StartView   x="0" y="0" />
        </s:NavigatorContent>
        <s:NavigatorContent id="documentTab" minWidth="950"  minHeight="300"  label="Document">
            <documentview:DocumentView  x="0" y="0" visible="model.documentList" />
            <documentdetailview:DocumentDetailView  x="0" y="0" visible="model.documentDetail "/>
        </s:NavigatorContent>
</mx:TabNavigator>

在列表中,我有一列带有调用函数 setDocumentDetailView() 的“详细信息”链接:

public function setDocumentDetailView() : void 
    documentList = false; // the list is not displayed
    documentDetail = true; // the detail is displayed

在详细视图中,我有一个返回列表调用函数 setDocumentListView() 的按钮:

public function setDocumentListView() : void 
    documentList = true; // tje
    documentDetail = false;
    setDocumentDetailViewHeight(300);

到目前为止,一切正常。

由于列表和细节的最小高度不同,会出现第一个问题。要显示垂直滚动条并显示特定视图的所有内容,必须设置 NavigatorContent id="documentTab" 的最小高度。这是在上面的函数中完成的。

出现更多问题是因为细节取决于显示的文档。它由几个具有条件可见性的面板组成。因此,各种文档的最小高度是不同的(根据其类型以及文档文本的长度)。因此需要根据内容确定minHeight,并相应设置“documentTab”的minHeight。

我找到了在视图呈现后调用的“updateComplete”事件。如果我得到包含所有条件面板的 VGroup 的高度值,我就需要为外部 NavigatorContent“documentTab”设置正确的高度。我将此高度传递给 MainModel 中设置选项卡的 minHeight 的函数。

public function onUpdateComplete(): void 
        if (MainViewModel.getInstance().documentDetail) 
            height = view.documentDetail.height;
            MainViewModel.getInstance().setDocumentDetailViewHeight(height);
        
    

这似乎也能正常工作。直到...

我最近发现,如果我遵循以下场景,它会失败:

    显示文档列表。 显示文档 A 的详细信息。 返回列表。 显示同一个文档A。

在这种情况下,不会重新渲染详细视图,因为显示的对象是相同的,具有相同的高度和宽度。因此,updateComplete 事件没有被触发,minHeight 保持设置为 300(因为上一步中设置的列表 minHeight)。详细信息中的面板越过外部“documentTab”并且不会出现滚动条。当我转到另一个内容相似的文档(可见相同的面板和相同的比例)时,也会出现相同的情况。

对于这种情况,有人有可行的解决方案吗?

我什至已经尝试过“显示”事件来将高度设置为存储在属性中的值。但它没有用。更糟糕的是,它开始表现得很奇怪,因为“height”变量的值只设置为比以前更大的值,但从未变小。当视图可能更小时,变量会保留以前大小的值。当视图需要更大的高度时,该变量会采用新的更高值。这导致在访问各种文档的详细信息并保持这个大高度时,将视图永久调整为最大发现大小 - 为所有文档详细信息提供大量空白空间和滚动条。

我已经厌倦了 Flex 的这种不可预测的行为 :( 所以,如果有人知道我应该尝试什么来完成这项工作,我会非常高兴。

【问题讨论】:

【参考方案1】:

我不确定这是否能解决您的问题,没有完整的代码很复杂,首先我建议您使用带有 View stack 的 tabBar,然后使用这样的导航内容

<s:TabBar dataProvider="myViewStack" styleName="tabText" />
   <mx:ViewStack id="myViewStack" paddingTop="0"   resizeToContent="true" creationPolicy="all">    

        <!-- TAB 1-->                           
        <s:NavigatorContent id="familyTab" label="Familia" >
            <Code/>
        </s:NavigatorContent>

        <!-- TAB 2 -->
        <s:NavigatorContent id="subFamilyTab" label="SubFamilia" >
            <Code/>     
        </s:NavigatorContent>

    </mx:ViewStack>

我不明白为什么你需要 minHeigh evrything 是动态的,所以如果你在 2n 选项卡中使用 hgroup,我肯定 evrything 会与/heigh 配合得很好。如果您在滚动时遇到问题,请使用滚动标签

<s:NavigatorContent id="documentTab" minWidth="950"  minHeight="300"  label="Document">
<s:VGroup width=100% heigh=100%>
            <documentview:DocumentView  x="0" y="0" visible="model.documentList" />
            <documentdetailview:DocumentDetailView  x="0" y="0" visible="model.documentDetail "/>
</s:VGroup>
        </s:NavigatorContent>

在您在此 mxml 文件中使用的第一个组(vgroup 或 hgroup)上使用 s:scroller

【讨论】:

以上是关于Flex中容器问题的动态minHeight的主要内容,如果未能解决你的问题,请参考以下文章

如何安排弹性项目以占据容器的整个宽度?

自定义 Flex 3 容器

Flex布局

使 flex-box 中的元素占用动态空间量(如果两个元素则为 50%,如果三个元素则为 33% 等)[重复]

CSS Flex 布局的引入背景

css中flex布局导致容器中图片被压缩问题