簡體   English   中英

如何通過 ASP 按鈕從 Gridview 中的特定單元格中獲取值? ASP.NET C#

[英]How do I grab values from specific cells in a Gridview via ASP Button ? ASP.NET C#

當我單擊 ASP 按鈕啟動 function 時,它會遍歷 gridview,但值是空字符串。 我要做的事情是允許我的用戶通過“拖放”重新訂購 gridview,然后將所有項目保存在 gridview 中的新順序。 這是關鍵,當他們單擊按鈕時,我想遍歷 Gridview 中的第一列,看看在重新排序方面是否有任何規則被破壞,如果沒有規則被破壞...... sortOrder(隱藏列)將被更新。 然后新的重新排序和更新的 SortOrder 值將通過存儲過程傳回數據庫表。

到目前為止,我正在單擊按鈕以通過嵌套 for 循環遍歷 gridview 的第一列,並且在遍歷時,沒有拾取任何值。 它們都被視為空字符串。

這是 Gridview ASPX 代碼:

  <asp:GridView ID="gridComments" runat="server" BackColor="White" BorderColor="#999999" DataKeyNames="RecNo" OnRowDeleting="gridComments_RowDelete" OnSelectedIndexChanged="gridComments_SelectedIndexChanged"
                        OnRowDataBound="gridComments_RowDataBound" OnRowUpdating="gridComments_RowUpdating" BorderStyle="Solid" BorderWidth="1px" CellPadding="3" ForeColor="Black" GridLines="Vertical" AutoGenerateColumns="False" Width="90%">
                        <FooterStyle BackColor="#CCCCCC" />
                        <SelectedRowStyle BackColor="#000099" Font-Bold="True" ForeColor="White" />
                        <PagerStyle BackColor="#999999" ForeColor="Black" HorizontalAlign="Center" />
                        <HeaderStyle BackColor="Black" Font-Bold="True" ForeColor="White" />
                        <AlternatingRowStyle BackColor="#CCCCCC" />
                        <Columns>
                            <asp:TemplateField HeaderText="Edit">
                                <ItemStyle Wrap="false" />
                                <ItemTemplate>
                                    <asp:LinkButton runat="server" ID="lnkEdit" CommandName="select" Text='<%# Eval("Program") %>' CausesValidation="false"></asp:LinkButton>
                                </ItemTemplate>
                            </asp:TemplateField>
                            <asp:TemplateField HeaderText="Description">
                                <ItemStyle Width="80%" HorizontalAlign="Left" />
                                <ItemTemplate>
                                    <asp:Label runat="server" ID="lblDescription" Text='<%# Eval("Preview") %>'></asp:Label>&nbsp;&nbsp;
                        <asp:LinkButton runat="server" ID="lnkEditComment" Text="Edit"></asp:LinkButton>
                                    <ajaxToolkit:ModalPopupExtender ID="modalPopup" runat="server" PopupControlID="pnlCommentInfo" TargetControlID="lnkEditComment" BackgroundCssClass="modalBackground" CancelControlID="btnCancel"></ajaxToolkit:ModalPopupExtender>
                                    <asp:Panel ID="pnlCommentInfo" runat="server" Style="display: none; text-align: left" CssClass="pnlPop" BorderStyle="Double" Width="500px" ScrollBars="Auto">
                                        <asp:Label runat="server" ID="lblCommentNumber"></asp:Label><br />
                                        <br />
                                        Comment:<br />
                                        <asp:TextBox ID="txtEditComment" runat="server" Rows="6" TextMode="MultiLine" Columns="58" /><br />
                                        <br />
                                        <asp:Button ID="btnSave" runat="server" Text="Save" CausesValidation="false" CommandName="Update" />
                                        <asp:Button ID="btnCancel" runat="server" Text="Cancel" CausesValidation="false" />
                                    </asp:Panel>
                                </ItemTemplate>
                            </asp:TemplateField>

                            <asp:TemplateField>
                                <ItemTemplate>
                                    <asp:LinkButton runat="server" ID="lnkDelete" CommandName="delete" Text="Delete"></asp:LinkButton>
                                </ItemTemplate>
                            </asp:TemplateField>

                            <asp:TemplateField >
                                <HeaderStyle  CssClass =" HiddenCol"/>
                                <ItemStyle CssClass ="HiddenCol" />
                                <ItemTemplate >
                                     <%# Eval("SortOrder") %>

                                </ItemTemplate>
                            </asp:TemplateField>
                        </Columns>
                    </asp:GridView> 

<div style="clear:both">
                        <asp:Button ID="HiddenButton" runat="server" Text="" style="display:none"  BackColor="Transparent" Width="30px"/>
                        <asp:Button ID="Button1" runat="server" OnClick="SaveReorder_Click" Text="Save Ordering Changes" />


                    </div>

                     <asp:Panel ID="StatusPanel" runat="server" CssClass="modalPopup"  Height="123px" Width="292px" style="display:none">
                <div style="text-align: center">
                 <p> ERROR: Please place comments by program in numerical order from least to greatest. Please try again.

                 </p>
            <div style="text-align: center; height: 21px"  >
                    <input id="OK" type="button" value="OK" />
                </div>

                   </div>
        </asp:Panel>

                    <ajaxToolkit:ModalPopupExtender ID="ModalPopupExtender1" runat="server" BackgroundCssClass="modalBackground" PopupControlID="StatusPanel" OkControlID="OK"  CancelControlID="OK"  TargetControlID="HiddenButton">

                 </ajaxToolkit:ModalPopupExtender>
                </div>

這是我在代碼隱藏文件中創建的 Function:

我只是在這一步,如果他們對數據重新排序錯誤,則會出現一個彈出窗口。 如果他們正確執行,則可以在更新 SortOrder 列(隱藏列)后將更新保存到數據庫中

protected void SaveReorder_Click(object sender, EventArgs e)
    {



        for (int i = 0; i < gridComments.Rows.Count -1; i++ )
        {
               for(int j = i+1; j < gridComments.Columns.Count ; j++)
               {

                   //if (Convert.ToInt32(gridComments.Rows[i].Cells[0].Text) > Convert.ToInt32(gridComments.Rows[j].Cells[0].Text))
                   if (Convert.ToInt32(gridComments.Rows[i].Cells[0].Text) > Convert.ToInt32(gridComments.Rows[j].Cells[0].Text))
                   {
                       ModalPopupExtender1.Show();
                   }

               }
        }


    }```

如果您嘗試訪問該行的第一個單元格,我認為您不會基於Text返回任何內容,因為第一列呈現一個控件。 也就是說,除非您的OnRowDataBound中有更多內容可以更簡單地填充第一列。

如果你看這里: https://stackoverflow.com/a/13795757/2951086他們正在考慮提取列的值,並且在嘗試使用TemplateField通過其列的Cell.Text訪問它時遇到問題。 鏈接的答案建議在單元格中找到控件,如下所示以訪問 Text 屬性(如果您嘗試使用第一列的 LinkButton 的 Text 字段,則更改為匹配):

    LinkButton lb = (LinkButton)gridComments.Rows[i].Cells[0].FindControl("lnkEdit");
    // use lb.Text as you see fit

此外,我不確定它是否重要,但看起來您正在使用j的列數來迭代一系列行,這似乎是有問題的。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM