![](/img/trans.png)
[英]how can i bind the button to data which is coming from db in gridview c# asp.net
[英]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>
<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.