合并Gridview 行

 
 #region 合并GridView中某列相同信息的行(单元格)
    /// <summary>
    /// 合并GridView中某列相同信息的行(单元格)
    /// </summary>
    /// <param name="GridView1">GridView</param>
    /// <param name="cellNum">第几列</param>
    public static void GroupRows(GridView GridView1, int intColNum, ArrayList list)
    {
        int i = 0, rowSpanNum = 1;


        for (int j = 0; j < intColNum; j++)
        {

            while (i < GridView1.Rows.Count - 1)
            {
                GridViewRow gvr = GridView1.Rows[i];
                for (++i; i < GridView1.Rows.Count; i++)
                {
                    GridViewRow gvrNext = GridView1.Rows[i];

                    //纵向相邻单元格的内容相同
                    //找出使用隐藏字段存储的值,这是关键3.
                    //sss = ((Label)gvr.Cells[j].FindControl("" + list[3].ToString() + "")).Text + ((Label)gvr.Cells[j].FindControl("" + list[0].ToString() + "")).Text;

                    if (j != 5)
                    {
                        if (((Label)gvr.Cells[j].FindControl("" + list[j].ToString() + "")).Text.Trim().ToString() == ((Label)gvrNext.Cells[j].FindControl("" + list[j].ToString() + "")).Text.Trim().ToString() && ((Label)gvr.Cells[j].FindControl("lbldxid")).Text.Trim().ToString() == ((Label)gvrNext.Cells[j].FindControl("lbldxid")).Text.Trim().ToString())
                        {
                            gvrNext.Cells[j].Visible = false;
                            rowSpanNum++;
                        }
                        else
                        {
                            gvr.Cells[j].RowSpan = rowSpanNum;
                            rowSpanNum = 1;
                            break;

                        }
                    }
                    else
                    {


                        if (list[5].ToString() == "txtpf")
                        {
                            if (((TextBox)gvr.Cells[j + 1].FindControl("txtpf")).Text.Trim().ToString() == ((TextBox)gvrNext.Cells[j + 1].FindControl("txtpf")).Text.Trim().ToString() && ((Label)gvr.Cells[j + 1].FindControl("lbldxid")).Text.Trim().ToString() == ((Label)gvrNext.Cells[j + 1].FindControl("lbldxid")).Text.Trim().ToString())
                            {
                                gvrNext.Cells[j + 1].Visible = false;
                                rowSpanNum++;
                            }
                            else
                            {
                                gvr.Cells[j + 1].RowSpan = rowSpanNum;
                                rowSpanNum = 1;
                                break;

                            }
                        }

                    }
                    if (i == GridView1.Rows.Count - 1)
                    {
                        if (j == 5)
                        {
                            gvr.Cells[j + 1].RowSpan = rowSpanNum;
                        }
                        else
                        {
                            gvr.Cells[j].RowSpan = rowSpanNum;
                        }


                    }
                }

            }
            i = 0;
            rowSpanNum = 1;


        }



    }
    #endregion
 
 
调用方法:

   ArrayList list = new ArrayList();                 list.Add("lbldxmc");                 list.Add("lblxxbt");                 list.Add("lblkhsm");                 list.Add("lblkhyq");                 list.Add("xxfs");                 list.Add("txtpf");                 BindDx();//绑定数据源

                GroupRows(GridView1, 6, list); //关键1,发出请求时合并显示第几列


效果图:
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在WPF中实现GridView合并可以通过使用DataTemplateSelector和GridViewGroupStyle来实现。 首先,我们需要创建一个继承自DataTemplateSelector的类,该类将用于根据数据项的特定条件选择合适的数据模板。在这个类中,我们可以重写SelectTemplate方法,根据需要合并来选择不同的数据模板。 接下来,在XAML中定义GridView时,我们可以使用ItemsPanel来定义GridView的布局,例如使用StackPanel来垂直排列。然后,我们需要使用GroupStyle属性来定义合并的样式。在GroupStyle中,我们可以使用HeaderTemplate来定义组的标题,同时还可以设置HeaderContainerStyle来自定义标题的样式。 在数据绑定方面,我们需要使用CollectionViewSource来对数据进分组。我们可以使用GroupDescription属性来指定分组的属性,同时还可以使用GroupStyleSelector属性来指定分组的样式。 最后,在合适的位置使用我们定义的DataTemplateSelector类,将其赋值给GridView的ItemTemplateSelector属性,以便根据条件选择合适的数据模板来实现合并效果。 通过以上的步骤,我们就可以实现在WPF中使用GridView实现合并的效果了。注意,具体的实现可能会因具体的业务需求而有所不同,以上只是一个大致的指导思路。 ### 回答2: 在WPF中,GridView(网格视图)是用于显示和管理数据的控件之一。虽然GridView本身并不直接支持合并的功能,但我们可以通过一些技巧和代码逻辑来实现合并的效果。 首先,我们可以使用DataTemplateSelector来自定义每个单元格的显示方式。通过继承DataTemplateSelector并重写SelectTemplate方法,我们可以根据数据项的不同来选择不同的数据模板。在数据模板中,我们可以将需要合并的单元格设置为透明或者空白,以达到合并的效果。 其次,我们可以使用自定义的GroupStyle来实现合并。我们可以通过创建一个名为"GroupStyle"的GroupStyleCollection,并向其中添加一个自定义的GroupStyle。在该GroupStyle中,我们可以指定该分组的HeaderTemplate,并在HeaderTemplate中使用Grid控件来实现合并的效果。通过调整Grid控件的和列的合并方式以及合并的单元格范围,我们可以将多合并一行。 最后,我们还可以使用第三方的扩展库来实现合并的功能。例如,可以使用Syncfusion公司的WPF控件库中的GridGroupingControl控件来实现合并效果。该控件具有内置的合并功能,并且可以通过简单的设置和配置来实现。 总之,要在WPF中实现GridView合并效果,我们可以通过使用DataTemplateSelector、自定义GroupStyle或者借助第三方的扩展库来达到我们的目的。根据具体的需求和项目的复杂程度,我们可以选择合适的方法来实现合并功能。 ### 回答3: WPF的GridView控件是用于显示和编辑数据的强大工具,但是它本身不支持合并操作。但是我们可以通过一些技巧来实现合并的效果。 一种常见的实现合并的方法是使用自定义DataTemplate。我们可以通过使用Grid或StackPanel等容器控件来自定义每个单元格的布局,并使用数据绑定来填充每个单元格的数据。然后,根据需要合并的内容,我们可以使用多个数据绑定来显示相同的内容。 另一种实现合并的方法是使用自定义的数据逻辑。我们可以通过从数据源中检查相邻的值来判断是否应该合并。然后,我们可以在GridView的LoadingRow事件中动态设置RowSpan属性来实现合并操作。 以下是一个示例展示如何使用自定义的数据逻辑来实现合并: ``` private void GridView_LoadingRow(object sender, DataGridRowEventArgs e) { // 获取当前和上一行的数据 YourData currentItem = e.Row.DataContext as YourData; YourData previousItem = (YourData)GridView.Items[GridView.Items.Count - 1]; if (previousItem != null && currentItem != null) { // 检查是否应该合并 if (currentItem.SomeProperty == previousItem.SomeProperty) { // 设置前一行的RowSpan属性 e.Row.Header = ""; e.Row.HeaderTemplate = null; e.Row.HeaderStyle = null; Grid.SetRowSpan(e.Row, 2); } } } ``` 以上是使用两种常见的方法来合并的示例。当然,具体的实现方式还可以根据具体需求进调整。希望能对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值