asp.net gridview奇怪的行为

时间:2012-02-22 20:06:10

标签: c# asp.net gridview

在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;
}

我通常不会发布我的所有代码,但我迫不及待地想要解决这个问题。我非常感谢任何帮助。

提前致谢!

2 个答案:

答案 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" />
....

这样做的好处是,如果您需要在应用程序中的任何其他位置使用该列,则可以轻松重复使用。