在gridview和datagrid里设置列宽

本文介绍如何在ASP.NET中使用GridView和DataGrid时,根据绑定的数据动态调整列宽,确保显示效果最佳。
<script>function StorePage(){d=document;t=d.selection?(d.selection.type!='None'?d.selection.createRange().text:''):(d.getSelection?d.getSelection():'');void(keyit=window.open('http://www.365key.com/storeit.aspx?t='+escape(d.title)+'&u='+escape(d.location.href)+'&c='+escape(t),'keyit','scrollbars=no,width=475,height=575,left=75,top=20,status=no,resizable=yes'));keyit.focus();}</script>

无论是gridview还是datagrid,在绑定数据后,列宽都不是固定的,在设计时是没法设定的,只能通过绑定是触发的事件来重新设定。参考http://msdn2.microsoft.com/zh-cn/library/ms178296(VS.80).aspx 的解释。

gridview的代码:

protectedintwidestData;
protectedvoidGridView1_RowDataBound(objectsender,
GridViewRowEventArgse)
{
System.Data.DataRowViewdrv;
drv
=(System.Data.DataRowView)e.Row.DataItem;
if(e.Row.RowType==DataControlRowType.DataRow)
{
if(drv!=null)
{
StringcatName
=drv[1].ToString();
Response.Write(catName
+?¡ã/?¡À);
intcatNameLen=catName.Length;
if(catNameLen>widestData)
{
widestData
=catNameLen;
GridView1.Columns[
2].ItemStyle.Width=
widestData
*30;
GridView1.Columns[
2].ItemStyle.Wrap=false;
}
}
}
}
protectedvoidPage_Load(objectsender,EventArgse)
{
widestData
=0;
}

datagrid 的代码:

protectedvoiddatagrid_ItemCreated(objectsender,DataGridItemEventArgse)
{
ListItemTypeitemType
=e.Item.ItemType;
if(itemType==ListItemType.Header)
{
for(inti=0;i<e.Item.Cells.Count;i++)
{
e.Item.Cells[i].Width
=Unit.Pixel(80);
e.Item.Cells[i].Wrap
=false;
}
}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值