将Web用户控件添加到页面时,不会触发Asp按钮onclick

时间:2015-12-01 20:36:42

标签: javascript c# html asp.net web-controls

我正在使用我使用visual studio模板创建的Web表单应用程序。模板具有内容占位符,该内容占位符由正在访问的任何页面的内容替换。有问题的页面有几个服务器控件,如文本框,标签和按钮。当我点击我的更新按钮时它正常工作,值回发并更新我的数据库。

我想在所有子页面中创建一个通用的登录提示。我的导航栏位于我的母版页中,是一个自举设置。我在导航栏中添加了一个下拉列表项,我在其中放置了一个Web用户控件,其中包含一个用于登录的表单。一旦我添加了Web用户控件,onclick事件就不再触发了,我也遇到了控件验证问题(错误表示无效的回发或参数回调)。我在我的网络配置中关闭了事件验证,我解决了控件无法正常工作的一个问题,但现在我仍然遇到没有触发的onclick事件的问题。我在这里可能缺少什么想法?

<ul class="nav navbar-nav navbar-right">
                    <li class="dropdown">
                        <a id="loginIcon" href="#" class="dropdown-toggle" data-toggle="dropdown" runat="server">Login<b class="caret"></b></a>
                        <ul class="dropdown-menu">
                            <li>
                                <LoginUserControl:Login ID="loginFormControl" runat="server"/>
                            </li>
                        </ul>
                    </li>
                </ul>

<form id="login">
<div class="login-content" id="loginContainer" runat="server">
    <fieldset id="inputs">
        <asp:TextBox ID="txtUserName" runat="server" placeholder="Your username" required="true"></asp:TextBox>
        <asp:TextBox ID="txtPwd" runat="server" TextMode="Password" placeholder="Password" require="true"></asp:TextBox>
    </fieldset>
    <fieldset id="actions">
        <asp:Button ID="btnLogin" CssClass="submit" runat="server" Text="Login" OnClick="checkUser"></asp:Button>
        <%--<asp:CheckBox ID="chkRemember" runat="server" Checked="true"></asp:CheckBox>Remember me--%>
    </fieldset>
    <%--<a href="#" style="float: right;">Forgot password?</a>
    <a href="#">Sign up</a>--%>
</div>
<div class="login-content" id="logoutContainer" visible="false" runat="server">
    <fieldset id="logoutAction">
        <asp:Button ID="btnLogout" CssClass="submit" runat="server" Text="Logout" OnClick="logoutUser"></asp:Button>
    </fieldset>
</div>

            <div class="w3-half">
                <div class="w3-row-padding">
                    <asp:Label ID="setPointsLbl" Text="Setpoints" CssClass="controlsLlb" runat="server"></asp:Label>
                </div>
                <div class="w3-row-padding">
                    <asp:Label Text="High:" runat="server"></asp:Label>
                    <asp:TextBox CssClass="controlsTb" ID="highSetPoint" runat="server"></asp:TextBox>
                </div>
                <div class="w3-row-padding">
                    <asp:Label Text="Low:" runat="server"></asp:Label>
                    <asp:TextBox CssClass="controlsTb" ID="lowSetPoint" runat="server"></asp:TextBox>
                </div>
                <div class="w3-row-padding">
                    <asp:Button ID="updateBtn" CssClass="btn btn-default rightFloat" Text="Update" OnClick="UpdateSetPoints" runat="server" />
                </div>
            </div>

上面的代码显示我的母版页将用户控件添加到列表中, 用户控件中的html,然后是我子页面中的一些html。

1 个答案:

答案 0 :(得分:1)

这种情况正在发生,因为页面中有2个表单元素。在asp.net中,整个站点(主页和子页面)只允许使用1个表单。 该怎么办。 删除表单id = login