如何在slickgrid中完成多列分组?

时间:2012-05-24 08:59:52

标签: grouping slickgrid expand

我是slickgrid的新手。我已经完成了一些滑动网格和基础知识的例子。我有一个场景,我需要基于多个列进行分组,但是slickgrid分组基于单个列。

如何在slickgrid中完成multilpe列分组,并在每个组上展开和折叠功能?

任何了解此解决方案的人,都要以基本的方式解释,因为我刚接触到slickgrid。

我的要求就像在此链接slickgrid-grouping-example中对行本身进行分组一样。此示例用于基于一列进行分组。我的要求是基于多列进行分组

3 个答案:

答案 0 :(得分:4)

我知道问题已经过时但我不久前就使这个功能成为可能,并且在我名下的Github上的SlickGrid项目队列中得到了拉取请求。你也许可以尝试一下并给我一些反馈。我修改了3个文件,包括示例文件。此时,我不知道我的提交是否会被接受,因此请自行承担风险,但我对我的解决方案非常有信心,因为我已经在工作中使用它。 以下是指向它的链接:https://github.com/mleibman/SlickGrid/pull/522/files

以下是3个多列分组的示例,此代码部分来自我修改过的example-grouping.html文件。定义多个分组与数组一起工作,与之前的实现非常相似,只需在定义多个分组时将其包装在数组中。

function groupByDurationPercentageStart() {
  dataView.groupBy(
    ["duration", "percentComplete", "start"],
    [
      (function (g) {
        return "Duration:  " + g.value + "  <span style='color:green'>(" + g.count + " items)</span>";
      }),
      (function (g) {
        return "Complete:  " + g.value + "  <span style='color:green'>(" + g.count + " items)</span>";
      }),
      (function (g) {
        return "Start Date:  " + g.value + "  <span style='color:green'>(" + g.count + " items)</span>";
      })
    ],
    [
      function (a, b) {
        return a.value - b.value;
      },
      function (a, b) {
        return a.value - b.value;
      },
      function (a, b) { // string sorting
        var x = a.value, y = b.value;
        return x == y ? 0 : (x > y ? 1 : -1);
      }
    ]
  ); 
  dataView.setAggregators([
    new Slick.Data.Aggregators.Avg("percentComplete"),
    new Slick.Data.Aggregators.Sum("cost")
  ], true, false);     
}

希望它可以帮助你们,现在它确实拥有所有功能,我喜欢这个网格=)

答案 1 :(得分:2)

我想你正在寻找这样的功能?

http://bit.ly/JTlf0z 要么 http://bit.ly/KuncBU

以上示例来自ExtJS网格和jQuery.easyUI插件。

这似乎是SlickGrid目前无法提供的东西(我不是SlickGrid专业版,这正是我从一些谷歌搜索推断的)。您很可能必须自己编写代码。

(当然,如果您不想切换到上面提到的网格之一;)。)

深入了解源代码,找到生成列和列标题的位置,然后开始处理它。您可以检查上面提到的其他网格,以获得有关实现此功能的一些指导(关于HTML标记和使用的CSS)。

您很可能必须修改“列”数组的定义方式,以包含列分组标题上的数据。

类似的东西:

var columns = [
  {title:'Group 1', columns:[
    {id: "field1", name: "Field 1", field: "field1"},
    {id: "field2", name: "Field 2", field: "field2"},
  ]},
  {id: "field3", name: "Field 3", field: "field3"},
  {title:'Group 2', columns:[
    {id: "field4", name: "Field 4", field: "field4"},
    {id: "field5", name: "Field 5", field: "field5"},
    {id: "field6", name: "Field 6", field: "field6"},
  ]}
];

然后修改列生成代码以检查是否存在嵌套的“列”字段并使用它来生成列标题?

只是一个想法:)。希望有所帮助。

答案 2 :(得分:2)

实际上,滑板网格分组不仅限于一列。
查看DataView API以获取groupBy方法。它有以下签名:

function groupBy(valueGetter, valueFormatter, sortComparer){...}

所以你感兴趣的是第一个参数。它可以是一个String,表示要按OR分组的单个列名称,它可以是一个函数。 TA-DA!
简而言之,以下是如何按多列分组:

  dataView.groupBy(
      //Grouping value
      function (row) {
          return row["groupColumn1"]+":"+row["groupColumn2"]+":"+row["groupColumn3"];
      },
      //Group display
      function (group) {
       var values = g.value.split(":", 3); //3 is number of grouping columns*
       return "Col1: "+values[0]+", Col2: "+values[1]+", Col3:" + values[2];
      },
      //Group comparator/sorting
      function (a, b) {
          return a.value - b.value;
      }
  );