在 Flex 中 AdvancedDatGrid, ,我们做了很多分组。大多数列对于父母和孩子来说都是相同的,所以我想将组的第一个值显示为摘要,而不是 MAX、MIN 或 AVG

此代码适用于数字值,但不适用于文本值(如果没有注释行,您将得到 NaN):

private function firstValue(itr:IViewCursor,field:String, str:String=null):Object 
{
  //if(isNaN(itr.current[field])) return 0  //Theory: Only works on Numeric Values?
  return itr.current[field]
}      

XML:

(mx:GroupingField name="Offer")
  (mx:summaries)
    (mx:SummaryRow summaryPlacement="group")
      (mx:fields)
        (mx:SummaryField dataField="OfferDescription"   label="OfferDescription" summaryFunction="firstValue"/)
        (mx:SummaryField dataField="OfferID"   label="OfferID" summaryFunction="firstValue"/)
        (/mx:fields)
    (/mx:SummaryRow)
  (/mx:summaries)
(/mx:GroupingField)

OfferID的工作正确, OfferDescription不。

有帮助吗?

解决方案

看起来summaryFunction 必须返回一个数字。根据 Adobe 错误跟踪器, ,这是文档中的一个错误:

萨米尔·巴特评论:

在文档中提到的是 - 总的内置摘要函数,用于总和,min,max,avg和计数all返回一个包含摘要数据的数字。

所以人们可以得到一个想法,但我同意你的观点,我们应该明确提到返回类型应该是数字。

我们将其保留为对象,以便将来可以轻松地在其中添加更多内容。

其他提示

如果您需要获取要显示的字符串,请使用 advanceDataGridColumn 上的 label 函数。这将呈现摘要行。

(mx:AdvancedDataGridColumn headerText="注释" width="140" dataField="注释" labelFunction="formatColumn" /)

            private function getNestedItem(item:Object):Object {

                try {
                    if (item.undefined[0]) {
                        item = getNestedItem(item.undefined[0]);
                    }
                } catch (e:Error) {
                    // leave item alone
                }
                return item;
            }           
            private function formatColumn(item:Object, column:AdvancedDataGridColumn):String {

                var output:String;
                // If this is a summary row
                if (item.GroupLabel) {

                    item = getNestedItem(item);
                } 

                switch (column.dataField) {

                    case 'comment':

                        return item.comment;


                }

            }
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top