4

在 FlexAdvancedDatGrid中,我们做了很多分组。大多数列对于父母和孩子都是相同的,所以我想将组的第一个值显示为摘要而不是 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不。

4

2 回答 2

3

如果您需要获取要显示的字符串,请使用高级数据网格列上的标签函数。这将呈现摘要行。

(mx:AdvancedDataGridColumn headerText="Comment" width="140" dataField="comment" 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;


                }

            }
于 2009-09-10T17:10:07.600 回答
1

看起来 summaryFunction 必须返回一个数字。根据Adob​​e bug tracker,这是文档中的一个错误:

萨米尔·巴特评论:

在文档中提到 - SUM、MIN、MAX、AVG 和 COUNT 的内置汇总函数都返回一个包含汇总数据的数字。

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

我们将它保留为一个对象,以便将来在其中添加更多内容变得容易。

于 2008-09-16T03:25:16.503 回答