DataGrid实现单元格合并

//填充DataGird

private void tableFill()
  {
   string strSql="select c.id,a.Content item ,b.Content from Assess_Item b left join (select * from Assess_Item where Grade=0) a on Left(RTrim(LTrim(b.ItemCode)),2)=a.ItemCode left join Assess_Relation c on c.ItemId=b.id where b.Grade=1 and c.PostTypeId=" + this.identityNo (this.peopleList .SelectedValue .Trim ()) + " order by a.Content";
   this.DataGridEx1 .DataSource =this.ExecuteReader (strSql,"ASOM");
   this.DataGridEx1 .DataBind ();
  }

//合并单元格

private void DataGridEx1_PreRender(object sender, System.EventArgs e)
  {
   int rowCount=this.DataGridEx1 .Items .Count ;
   int itemCount=0;
   int itemStart=0;
   for (int i=0;i<rowCount ;i++)
   {
    if(i==0)
     itemStart=0;
    else
    {
     string str1=this.DataGridEx1 .Items [i].Cells [1].Text .Trim ();
     string str2=this.DataGridEx1 .Items [itemStart].Cells [1].Text .Trim ();
     if(this.DataGridEx1 .Items [i].Cells [1].Text .Trim ()==this.DataGridEx1 .Items [itemStart].Cells [1].Text .Trim ())
     {
      itemCount+=1;
      this.DataGridEx1 .Items[i].Cells [1].Visible =false;
     }
     else
     {
        this.DataGridEx1 .Items [itemStart].Cells [1].RowSpan =itemCount+1;
        itemCount=0;
        itemStart=i;
     }
    }
   }

//如果取出的数据为空,不合并单元格
   if(rowCount>0)
       this.DataGridEx1 .Items [itemStart].Cells [1].RowSpan =itemCount+1;

  }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值