如何在asp.net中通过分页保留gridview内控件的状态?

问题描述 投票:0回答:1

我在这个GridView中添加了TextBox的验证,但是这个验证仅适用于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 c# asp.net gridview pagination
1个回答
0
投票

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

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

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

2、为文本框控件添加onclientclick属性,如

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

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

© www.soinside.com 2019 - 2024. All rights reserved.