如何控制DataGrid里的内容换行与不换行?

本文介绍了一种在ASP.NET应用程序中使用DataGrid组件时如何优化布局的方法,特别是在处理包含中英文混合且长度不一的文字内容时,通过调整样式属性和使用nobr标签防止文字自动换行,确保了良好的显示效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<%@ Page Language="C#" AutoEventWireup="True" %>
<%@ Import Namespace="System.Data" %>

<script runat="server">
int start_index;
ICollection CreateDataSource() 
{
  DataTable dt 
= new DataTable();
  DataRow dr;

  dt.Columns.Add(
new DataColumn("IntegerValue"typeof(Int32)));
  dt.Columns.Add(
new DataColumn("StringValue"typeof(string)));
  dt.Columns.Add(
new DataColumn("CurrencyValue"typeof(double)));

  
for (int i = start_index; i < start_index + ItemsGrid.PageSize; i++
  
{
    dr 
= dt.NewRow();    
    dr[
0= i;
    dr[
1= @"我是中文文字,I am English words,我不想换行,
            I don't wanna have new lines,欢迎访问 
            <a href='http://dotnet.aspx.cc/'>http://dotnet.aspx.cc/</a>,
            有好料啊:)
";
    dr[
2= 1.23 * (i+1);
    
    dt.Rows.Add(dr);
  }

    
  DataView dv 
= new DataView(dt);
  
return dv;
}


void Page_Load(Object sender, EventArgs e) 
{
  
//对于没有数字的内容,下面这行完全满足要求,但加了数字就不行,必须调用OnItemDataBound
  ItemsGrid.Attributes.Add("style","word-break:keep-all;word-wrap:normal");
    
  
//下面这行是自动换行
  
//ItemsGrid.Attributes.Add("style","word-break:break-all;word-wrap:break-word");
    
  
if (!IsPostBack)
  
{
    BindGrid();  
  }

}


void BindGrid() 
{
  ItemsGrid.DataSource
=CreateDataSource();
  ItemsGrid.DataBind();     
}


void Item_DataBound(Object sender, DataGridItemEventArgs e) 
{
  
if( e.Item.ItemType == ListItemType.Item ||
    e.Item.ItemType 
== ListItemType.AlternatingItem)
   e.Item.Cells[
1].Text = "<nobr>" + e.Item.Cells[1].Text + "</nobr>"
}




<form runat="server">
<asp:DataGrid id="ItemsGrid" runat="server" BorderColor="black"
    OnItemDataBound
="Item_DataBound" AutoGenerateColumns="false">

<AlternatingItemStyle BackColor="#DEDEDE"></AlternatingItemStyle>
<HeaderStyle BackColor="#EEEEFF" HorizontalAlign="Center"></HeaderStyle>

<Columns>
  
<asp:BoundColumn HeaderText="序号" DataField="IntegerValue"/>
  
<asp:BoundColumn HeaderText="文字" DataField="StringValue"/>
  
<asp:BoundColumn HeaderText="价格" DataField="CurrencyValue" DataFormatString="{0:c}">
  
<ItemStyle HorizontalAlign="right"></ItemStyle>
  
</asp:BoundColumn>
</Columns>

</asp:DataGrid>
</form>



 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值