0

現在、asp.net アプリにこの gridview OnRowDataBound メソッドがあります。

protected void gvwStatus_OnRowDataBound(object sender, GridViewRowEventArgs e)
{
    if (e.Row.RowType == DataControlRowType.DataRow)
    {
        string excsCost = e.Row.Cells[3].Text.ToString();
        //do stuff//
    }
}

マークアップ:

                                  <asp:GridView ID="gvwStatus" runat="server" CssClass="gridview" ShowHeaderWhenEmpty="True"
                                        AllowPaging="True" BackColor="Control" OnSorting="gvw_OnSorting" OnPageIndexChanging="gvwStatus_PageIndexChanging"
                                        OnRowDataBound="gvwStatus_OnRowDataBound" AllowSorting="True" AutoGenerateColumns="False"
                                        Width="98%" PageSize="100" Style="margin-left: 10px;">
                                        <Columns>
                                            <asp:TemplateField HeaderText="Item" SortExpression="ITEM_NO">
                                                <ItemTemplate>
                                                    <asp:LinkButton ID="lbtnItemNo" runat="server" CssClass="app_hyperlink" Text='<%#Eval("ITEM_NO") %>'
                                                        OnCommand="lbtnItemNo_OnClick" CommandArgument='<%#Eval("ITEM_NO") %>' />
                                                </ItemTemplate>
                                            </asp:TemplateField>
                                            <asp:BoundField DataField="ITEM_OBS_STATUS" HeaderText="Obs Status" SortExpression="ITEM_OBS_STATUS" />
                                            <asp:BoundField DataField="MIP_NO" HeaderText="MIP" SortExpression="MIP_NO" />
                                            <asp:BoundField DataField="LOT_FROM_EFF_DATE" HeaderText="Chgovr Date" SortExpression="LOT_FROM_EFF_DATE" />
                                            <asp:BoundField DataField="TRGT_CHGOVR_DATE" HeaderText="Target Date" SortExpression="TRGT_CHGOVR_DATE" />
                                            <asp:TemplateField HeaderText="Excess Cost" SortExpression="EXCS_ITEM_COST_TOT">
                                                <ItemTemplate>
                                                    <asp:Label ID="lblExcessCostStatus" runat="server" CssClass="app_label" Text='<%#string.Format("{0:C}", Eval("EXCS_ITEM_COST_TOT")) %>' />
                                                </ItemTemplate>
                                                <ItemStyle HorizontalAlign="Right" />
                                            </asp:TemplateField>
                                            <asp:BoundField DataField="SENT_TS" HeaderText="Sent to Plants/Vndrs" SortExpression="SENT_TS" />
                                        </Columns>
                                        <AlternatingRowStyle BackColor="White" />
                                        <PagerStyle HorizontalAlign="Left" />
                                        <PagerSettings Mode="NumericFirstLast" />
                                        <HeaderStyle CssClass="gvLinkNoUnderline" />
                                    </asp:GridView>

ここではインデックス作成が正しく機能していません。私の文字列 excsCost では、インデックス 3 (またはセル 4) からの値が必要であることを指定していますが、インデックス 5 (セル 6) から値を取得しています。インデックス 2 を指定すると、インデックス 0 から値を取得します。完全にずれているようです。

誰もこの問題に精通していますか?

4

1 に答える 1

0

実際に使用してItemTmplateいるので、プログラムでコントロールを取得し、コードで操作できます

   protected void gvwStatus_OnRowDataBound(object sender, GridViewRowEventArgs e)
    {


      if (e.Row.RowType == DataControlRowType.DataRow)
      {
         Label lblExcsCost = new Label();
         lblExcsCost = e.Row.FindControl("lblExcessCostStatus") as Label;
         string excsCost = lblExcsCost.Text();
      }
    }
于 2012-05-17T11:35:19.937 に答える