鸿运当头C#/Blazor/ASP.NET/WinForm/WebAPI

因为爱上你,我才懂得珍惜,每一天日记,都写满了甜蜜
因为想念你,我每天都可以,对着镜子说我多爱你,有多想见到你。

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
       一般我们在设计Grid的多行表头时,可能首先考虑到用Repeater或DataList,但现在我们可以用Infragistics的WebGrid来很轻松的实现这个功能,我们要实现的效果图如下:



实现这样的表头的代码如下:
在Grid的InitializeLayout事件下加入下面的代码:
        //
        
//设计多表头
        
//
        private void ut_grid105_InitializeLayout(object sender, Infragistics.WebUI.UltraWebGrid.LayoutEventArgs e)
        
{
            
foreach(Infragistics.WebUI.UltraWebGrid.UltraGridColumn c in e.Layout.Bands[0].Columns)
            
{
                c.Header.RowLayoutColumnInfo.OriginY 
= 1;
            }


            
//新建一个表头,设置它的显示名称
            Infragistics.WebUI.UltraWebGrid.ColumnHeader ch = new ColumnHeader(true);
            ch.Caption 
= "购进量";
            
//设置Y轴起始位置
            ch.RowLayoutColumnInfo.OriginY = 0;
            
//设置X轴起始位置
            ch.RowLayoutColumnInfo.OriginX = 4;
            
//设置该表头X轴方向占几列
            ch.RowLayoutColumnInfo.SpanX = 2;

            
//将该表头加入到我们的Grid中
            e.Layout.Bands[0].HeaderLayout.Add(ch);

            Infragistics.WebUI.UltraWebGrid.ColumnHeader ch1 
= new ColumnHeader(true);
            ch1.Caption 
= "消费量";
            ch1.RowLayoutColumnInfo.OriginY 
= 0;
            ch1.RowLayoutColumnInfo.OriginX 
= 6;
            ch1.RowLayoutColumnInfo.SpanX 
= 5;

            e.Layout.Bands[
0].HeaderLayout.Add(ch1);


            
foreach(Infragistics.WebUI.UltraWebGrid.UltraGridColumn c in e.Layout.Bands[0].Columns)
            
{
                
if(c.Key != "A02" && c.Key != "A03" && c.Key != "A04" && c.Key != "A05" && c.Key != "A06" && c.Key != "A07" && c.Key != "A08")
                
{
                    c.Header.RowLayoutColumnInfo.OriginY 
= 0;
                    c.Header.RowLayoutColumnInfo.SpanY 
= 2;
                }

            }


}

当然,我们还可以固定某一列或某几列,代码如下:

//固定列
            e.Layout.Bands[0].Columns.FromKey("zbmc").Header.Fixed = true;
            e.Layout.Bands[
0].Columns.FromKey("jldw").Header.Fixed = true;
            e.Layout.Bands[
0].Columns.FromKey("zbdm").Header.Fixed = true;

这样做的效果是,当我们水平拖动滚动条时,被固定的这几列是不随之而动的,适用于一些网上填写表格(表格横向很长)的情况.
posted on 2007-01-10 08:57  月异星邪  阅读(614)  评论(0编辑  收藏  举报