如何在网格视图中保留控件的状态,并在 asp.net 中分页

How do i preserve the state of a control inside gridview with paging in asp.net?

本文关键字:状态 并在 asp 分页 net 控件 网格 视图 保留      更新时间:2023-09-26

我在此网格视图中添加了文本框的验证,但此验证仅适用于 GridView 的当前页面(它不适用于 GridView 的上一页和下一页)。

<asp:GridView ID="Grd1" runat ="server" Width ="100%" AllowPaging ="true" pagesize="5">
  <Columns>
    <asp:BoundField HeaderText="Name" DataField="NM" ItemStyle-Width="300px" HeaderStyle-Width="300px" HeaderStyle-Wrap="false" ItemStyle-Wrap="false" />
    <asp:TemplateField HeaderText="Size (GB)">
      <ItemTemplate>
        <asp:TextBox ID="txtSize" runat="server" Width="100px"></asp:TextBox>
      </ItemTemplate>
    </asp:TemplateField>
  </Columns>
</asp:GridView>
<asp:Button ID="btnAdd" runat="server" Text="Save" OnClick="btnAdd_Click" />
<script language="javascript" type="text/javascript">
    function IsValidateAdd() {
        if (validateGridTextBox() == false)
            { return false; }
    }
    function validateGridTextBox() {
        var flag = false;
        var dropdowns = new Array(); //Create array to hold all the dropdown lists.
        var gridview = document.getElementById('<%=Grd1.ClientID %>'); //grvDMODetails is the id of ur gridview.
        dropdowns = gridview.getElementsByTagName('input'); //Get all dropdown lists contained in Grd1.            
        for (var i = 0; i < dropdowns.length; i++) {
            if (dropdowns.item(i).value != "") //If dropdown has no selected value
            {
                flag = true;
            }
            else 
            {
                flag = false;
                break;
            }
        }
        if (flag == false) 
        {
            alert('Please enter Table Size.');
            return flag;
        }
</script>

代码隐藏:

btnAddDM.Attributes.Add("onclick", "return IsValidateAdd();");

当您浏览上一页或下一页时,网格视图部分已更改,但javascript函数已绑定到原始网格视图,这就是它不起作用的原因。

如果你想让它工作,有2种解决方案

1,当您导航到其他页面时,再次手动绑定javascript验证功能。

2,将客户端单击属性添加到文本框控件中,例如

<asp:TextBox ID="txtSize" runat="server" Width="100px" onClientClick="validateGridTextBox(this)"></asp:TextBox>

并相应地更改您的 validateGridTextBox JavaScript 函数。

相关文章: