在ASP.NET中使用gridview控件时,我遇到了一个奇怪的问题。我正在使用分页。
网格中的第二列是“订单状态”列,其中包含诸如“D”,“S”等的值。“D”和“S”是表示“已交付”和“已发货”的数据库值。我们使用这些表示来节省数据库中的空间。
现在,在GridView中显示它时,我希望它显示为“显示”或“已发送”,而不是作为数据源的一部分的“D”和“S”。当我第一次加载页面时,我通过获取当前页面的行并在页面加载事件的帮助下使用“已交付”和“已发送”更改单元格的“D”和“S”来处理它。
但是,当我使用网格视图的分页控件转到下一页时会出现问题。
“订单状态”列中的值未更新到第二页中的“D”和“S”,因此我的功能将无法获取它们并且无法将它们转换为“已交付”并且“出货”。
我也尝试了OnPageIndexChanged
事件。即便如此:(
这是代码。
GRIDVIEW CONTROL
<asp:GridView ID="OrderGrid" runat="server" AllowPaging="True" AllowSorting="True"
AutoGenerateColumns="False" DataSourceID="OrderHistory" AlternatingRowStyle-CssClass="alt"
CssClass="order_grid" DataKeyNames="order_id" OnPageIndexChanging="OrderGrid_PageIndexChanging">
设定订单状态方法
public void SetOrderStatus()
{
string Delivered = "Delivered";
string Shipped = "Shipped";
string Processing = "Processing";
for (int i = 0; i < OrderGrid.Rows.Count; i++)
{
if (OrderGrid.Rows[i].Cells[1].Text == "D")
{
OrderGrid.Rows[i].Cells[1].Text = Delivered;
OrderGrid.Rows[i].Cells[1].BackColor = System.Drawing.Color.FromName("#127b41");
OrderGrid.Rows[i].Cells[1].ForeColor = System.Drawing.Color.FromName("#fdfdfd");
}
if (OrderGrid.Rows[i].Cells[1].Text == "S")
{
OrderGrid.Rows[i].Cells[1].Text = Shipped;
}
if (OrderGrid.Rows[i].Cells[1].Text == "P")
{
OrderGrid.Rows[i].Cells[1].Text = Processing;
}
}
}
PAGE INDEX CHANGING FUNCTION
protected void OrderGrid_PageIndexChanging(object sender, GridViewPageEventArgs e)
{
OrderGrid.PageIndex = e.NewPageIndex;
OrderGrid.DataBind();
SetOrderStatus();
string o = OrderGrid.Rows[0].Cells[1].Text;
}
我通常不会发布我的所有代码,但我迫不及待地想要解决这个问题。我非常感谢任何帮助。
提前致谢!
答案 0 :(得分:1)
尝试在RowDataBound事件中更新此内容。这允许您对每行的绑定进行调整。
这是一个例子: http://msdn.microsoft.com/en-us/library/system.web.ui.webcontrols.gridview.rowdatabound.aspx
答案 1 :(得分:1)
假设您使用BoundField表示相关列,您可以继承BoundField,并覆盖FormatData方法。
// untested code - should be approximately correct
public Class StatusBoundField:BoundField
{
protected override string FormatDataValue(Object dataValue,bool encode)
{
string value = dataValue as string;
string result = string.Empty;
if(!string.IsNullOrEmpty(value)
{
switch(value)
{
case "P": result = "Processed"; break;
case "S": result = "Shipped"; break;
case "D": result = "Delivered"; break;
default: result = "Unknown" // or string.Empty or throw an exception as appropriate
}
return base.FormatDataValue(result, encode);
}
}
然后在gridview声明中用你的类型替换绑定字段。
e.g。
// replace namespace and assembly as appropriate
<%@ Register TagPrefix ="my" Namespace="WebApplication1" Assembly="WebApplication1" %>
....
<asp:GridView ID="OrderGrid" runat="server" AllowPaging="True" AllowSorting="True"
AutoGenerateColumns="False" DataSourceID="OrderHistory" AlternatingRowStyle-CssClass="alt"
CssClass="order_grid" DataKeyNames="order_id">
<Columns>
<my:StatusField DataField="OrderStatus" HeaderText="Order Status"
SortExpression="OrderStatus" />
....
这样做的好处是,如果您需要在应用程序中的任何其他位置使用该列,则可以轻松重复使用。