【问题标题】:How to access a control inside of GridView如何访问 GridView 内部的控件
【发布时间】:2014-03-14 21:19:24
【问题描述】:

我对 ASP.NET 比较陌生,边走边学,我有以下问题:

我在 UpdatePanel 中定义了一个 GridView:

<asp:UpdatePanel ID="UpdatePanel1" runat="server">
 <ContentTemplate> 
   <div id="divIsoSelect" style="width:700px; height:60px; background-color:white">
    <fieldset>
        <legend style="font-size: larger; font-weight: bold">Search ISO by</legend>
 <table>
    <tr>
        <td>
         <asp:DropDownList ID="ddlISOSearch" runat="server" AutoPostBack="true" OnSelectedIndexChanged="ddlISOSearch_SelectedIndexChanged">
            <asp:ListItem Value="">Select...</asp:ListItem>
            <asp:ListItem Value="ISO Number" >ISO Number</asp:ListItem>
            <asp:ListItem Value="Name">Name</asp:ListItem>
            <asp:ListItem Value="Region" >Region</asp:ListItem>
            <asp:ListItem Value="Division">Division</asp:ListItem>                
            </asp:DropDownList></td>
           <td >&nbsp;</td>
        <td>
            <asp:Panel ID="pnlSearchEntry" runat="server" Visible="false" style="width:500px; border:gainsboro; border-width: thick;">
            <table>
            <tr>
                <td valign="middle" style="width:120px"><asp:Label ID="lblEntry" runnat="server" Text=""></asp:Label></td>

                <td valign="top"><asp:TextBox ID="txtSearchValue" runat="server"></asp:TextBox></td>

                <td valign="top">&nbsp;&nbsp;<asp:Button ID="btnFind" runat="server" Text="Select" OnClick="btnFind_Click"/></td>
            </tr>
            </table>
        </asp:Panel>
    </td>
    </tr>
</table>               
</fieldset>
</div>
        <div>    
        <p> <asp:Label ID="lblMsg" runat="server" style="position:absolute; left: 221px; top: 110px;"></asp:Label></p>
        </div>
        <div>

            <asp:GridView ID="grvIsoSearchResults" runat="server" 
                AutoGenerateColumns="False" PageSize="10"
                AllowPaging = "true" Visible="true"  BorderColor="Red" GridLines="Both"
                OnPageIndexChanged="grvIsoSearchResults_PageIndexChanged" 
                OnPageIndexChanging="grvIsoSearchResults_PageIndexChanging" 
                OnSelectedIndexChanged="grvIsoSearchResults_SelectedIndexChanged" 
                OnSelectedIndexChanging="grvIsoSearchResults_SelectedIndexChanging">
                <PagerSettings FirstPageText="First" LastPageText="Last" NextPageText="Next" PageButtonCount="100" />
                <Columns>
                   <asp:TemplateField HeaderText="ISONUM">
                        <ItemTemplate>
                            <asp:Label ID="txtgvIsoNum" Text = '<%# Eval("ISONUM")%>' runat="server" Width="70px" style="text-align:center" />
                        </ItemTemplate>
                    </asp:TemplateField>
                    <asp:TemplateField HeaderText="OFFICE NAME">
                        <ItemTemplate>
                            <asp:Label ID="txtgvIsoOfficeName" Text = '<%# Eval("ISOOFFICENAME")%>' runat="server" Width="200px" style="text-align:center" />
                        </ItemTemplate>
                    </asp:TemplateField>
                    <asp:TemplateField HeaderText="REGION">
                        <ItemTemplate>
                            <asp:Label ID="txtgvRegion" Text = '<%# Eval("REGION")%>' runat="server" Width="50px" style="text-align:center" />
                        </ItemTemplate>
                    </asp:TemplateField> 
                    <asp:TemplateField HeaderText="DIVISION">
                        <ItemTemplate>
                            <asp:Label ID="txtgvDivision" Text = '<%# Eval("CLIENT_ID")%>' runat="server" Width="50px" style="text-align:center" />
                        </ItemTemplate>
                    </asp:TemplateField>
                    <asp:TemplateField HeaderText="EMAIL ADDRESS">
                        <ItemTemplate>
                            <asp:TextBox ID="txtgvEmailAddress" Text = '<%# Eval("EMAIL")%>' runat="server" Width="300px" />
                            <asp:Button ID="btnUpdateEmail" Text = "Update" runat="server" Width="70px" OnClientClick="ValidateEmail()"/>
                        </ItemTemplate>
                    </asp:TemplateField>
                </Columns>
            </asp:GridView>                    
        </div>           

 </ContentTemplate>
</asp:UpdatePanel>
  <asp:UpdateProgress ID="UpdateProgress1" runat="server">
  <ProgressTemplate>
           Please Wait.....
  </ProgressTemplate>
  </asp:UpdateProgress>

现在我想验证我的电子邮件字段:

   function ValidateEmail()
   {
       var email = document.getElementById('<%=txtgvEmailAddress.ClientID%>').value;
   }

但我无法访问 gridview 中的电子邮件字段。我该怎么做才能解决它?

谢谢你

【问题讨论】:

    标签: javascript jquery html asp.net gridview


    【解决方案1】:

    如果目标是验证电子邮件地址是否有效,那么您可以使用 asp:RegularExpression 控件来执行此操作。将其包含在您的文本框控件下。摆脱 OnClientClick 您的按钮。

    <asp:RegularExpressionValidator ID="regexEmailValid" runat="server" ValidationExpression="\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*" ControlToValidate="txtgvEmailAddress" ErrorMessage="Invalid Email Format"></asp:RegularExpressionValidator>
    

    【讨论】:

    • 我已经试过了。发生的事情是,我在拥有有效电子邮件地址的每一行都收到错误消息。此外,我的 DropDown 部分在检查电子邮件后立即停止工作。在 DropDown 部分,我有一个单击按钮,应该搜索数据。验证执行后没有任何反应
    【解决方案2】:

    您必须将 rowindex 存储在 HTML hiddenfeild 中,该 HTML hiddenfeild 必须具有静态 clientidmode 属性....

    function ValidateEmail()
       {
        var rowindex=document.getElementById('hiddenfeild').value;
        if(document.getElementById('grvIsoSearchResults_txtgvEmailAddress_' + rowindex.toString() + '').value=="")
        {
          //write your code here
        }
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2015-07-31
      • 1970-01-01
      • 2010-10-11
      • 2013-05-09
      • 2011-07-12
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多