ASP.NET Wijmo的GridView 控件实现分组

ASP.NET Wijmo的GridView 控件可以支持从一个数据源显示项目,并且可以交互式选择、编辑、删除、排序和分组数据。本文介绍如何从一个数据源显示项目,并且根据拖拽到指定位置的列进行分组,组的最初可以是折叠也可以是展开,该表格在各组的头行旁边可以显示展开或折叠图标。分组的行可以显示汇总数据,例如,数量或金额。通过连接数据源,然后组头和组尾行用 wijmo-wijgrid-groupheaderrow和 wijmo wijgrid-groupfooterrow CSS类标记,就能实现如下效果的分组。<p><a href="http://www.grapecity.com.cn/image.ashx?picture=C1GridView-group.png"><img style="background-image: none; padding-left: 0px; padding-right: 0px; display: inline; padding-top: 0px; border-width: 0px;" title="C1GridView-group" src="http://www.grapecity.com.cn/image.ashx?picture=C1GridView-group_thumb.png" alt="C1GridView-group" width="643" height="481" border="0" /></a></p><p>&nbsp;</p>

发布于 2014/06/10 00:00

ComponentOne Enterprise

ASP.NET Wijmo的GridView 控件可以支持从一个数据源显示项目,并且可以交互式选择、编辑、删除、排序和分组数据。本文介绍如何从一个数据源显示项目,并且根据拖拽到指定位置的列进行分组,组的最初可以是折叠也可以是展开,该表格在各组的头行旁边可以显示展开或折叠图标。分组的行可以显示汇总数据,例如,数量或金额。

具体的实现步骤如下。

绑定数据源

拖拽C1GridView控件到页面,并且设置数据源。

<asp:sqldatasource id="SqlDataSource1" runat="server" connectionstring="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\C1NWind.mdb;Persist Security Info=True" providername="System.Data.OleDb" selectcommand="SELECT TOP 50 Products.ProductName, d.OrderID, d.Quantity, (d.UnitPrice * d.Quantity) as Total FROM Products INNER JOIN (SELECT details.ProductID, details.OrderID, details.UnitPrice, details.Quantity FROM [Order Details] AS details INNER JOIN (SELECT OrderID FROM Orders WHERE Year(OrderDate) = 1994) AS tmp ON details.OrderID = tmp.OrderID) as d ON Products.ProductID = d.ProductID ORDER BY d.ProductID">

</asp:sqldatasource>

C1GridView通过DataSourceID选择数据源,Columns的DataField选择数剧源的域。

分组

组头和组尾行用 wijmo-wijgrid-groupheaderrowwijmo wijgrid-groupfooterrow CSS类标记。 开发者应结合使用这些类与孩子\后裔以提供组行的自定义样式。 实现分组的代码如下:

<wijmo:C1GridView ID="C1GridView1" runat="server" DataSourceID="SqlDataSource1"

        AutoGenerateColumns="false" ShowGroupArea="true" AllowColMoving="true"

        AllowSorting="true" style="top: 520px; left: -9px">

        <Columns>

            <wijmo:C1BoundField DataField="ProductName" SortExpression="ProductName" HeaderText="产品名" Aggregate="Count">

                <GroupInfo Position="Header" OutlineMode="StartCollapsed" />

            </wijmo:C1BoundField>

            <wijmo:C1BoundField DataField="OrderID" SortExpression="OrderID" HeaderText="订单ID"></wijmo:C1BoundField>

            <wijmo:C1BoundField DataField="Quantity" SortExpression="Quantity" HeaderText="数量" Aggregate="Sum"></wijmo:C1BoundField>

            <wijmo:C1BoundField DataField="Total" SortExpression="Total" HeaderText="总计" Aggregate="Sum"></wijmo:C1BoundField>

        </Columns>

    </wijmo:C1GridView>

本文Demo中,通过C1GridView的AllowColMoving设置为true允许拖拽列。组头单元格被**.wijmo-wijgrid.TD wijmo wijgrid-groupheaderrow** CSS序列设计。并对产品名进行分组,分组后在组头显示产品名和数量的汇总数据。通过OutlineMode设置为StartCollaspsed实现分组最初所有组都是折叠的。

在页面显示出来后,点击分组组头的图标,就可以将分组展开或折叠。

该Demo的效果如下所示:

C1GridView-group

 

本文Demo的源代码如下:

C1GridView-grouping.7z (5.89 mb)

关于葡萄城

葡萄城是专业的软件开发技术和低代码平台提供商,以“赋能开发者”为使命,致力于通过表格控件、低代码和BI等各类软件开发工具和服务,一站式满足开发者需求,帮助企业提升开发效率并创新开发模式。葡萄城开发技术始于1980年,40余年来始终聚焦软件开发技术,有深厚的技术积累和丰富的产品线。是业界能够同时赋能软件开发和低代码开发的企业。凭借过硬的产品能力、活跃的用户社区和丰富的伙伴生态,与超过3000家合作伙伴紧密合作,产品广泛应用于信息和软件服务、制造、交通运输、建筑、金融、能源、教育、公共管理等支柱产业。

相关产品
推荐相关案例
关注微信
葡萄城社区二维码

关注“葡萄城社区”

活字格低代码二维码

关注“活字格低代码”

想了解更多信息,请联系我们, 随时掌握技术资源和产品动态