繁体   English   中英

Asp.net上的C#Textchanged事件触发两次

[英]c# Textchanged event on Asp.net is firing twice

我有一个简单的Webform来更改当前用户的密码,所以我有三个TextBoxes ,一个用于实际密码,另外两个用于确认我要保存的新密码。 当我尝试写入实际密码时,和我在数据库中输入的密码相同时,应该仅启用用于写入新密码的TextBox ,并且确实可以,但是我在TextChanged事件上放置了一个调试点,它触发了该时间为了启用我的TextBox ,但几乎立即触发,第二次启用了我的第二个TextBox ,但是我丢失了最初在第一个TextBox拥有的TextBox

任何想法为什么会这样?

protected void txt_passvieja_TextChanged(object sender, EventArgs e)
    {
        usuario_BLL bll = new usuario_BLL();
        usuario obj = new usuario();
        obj = bll.Leer(Session["usuario"].ToString());
        if (txt_passvieja.Text == obj.passwordUsuario)
        {
            txt_passwordnueva.Enabled = true;
        }
        else
        {
            lbl_header.Text = "Error";
            lbl_body.Text = "La contraseña ingresada no coincide con la base de datos";
            Page.ClientScript.RegisterStartupScript(this.GetType(), "myFunction", "myFunction()", true);
            Limpiar();
        }
    }

所以这是我的textchanged事件,我在“ txt_passwordnueva.Enabled = true;”中添加了一个调试点。 当我更改文本时,我看到它执行了两次此事件。 这是一个使用MasterPage的Webform,请注意,这是我遇到此问题的唯一形式。

这是我的Aspx代码:

    <%@ Page Title="" Language="C#" MasterPageFile="~/MasterPage.Master" AutoEventWireup="true" CodeBehind="CambiarContraseña.aspx.cs" Inherits="LegalCaseWeb.CambiarContraseña" %>
<%@ Register Assembly="AjaxControlToolkit" Namespace="AjaxControlToolkit" TagPrefix="ajaxToolkit" %>
<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="server">
    <link href="css/login.css" rel="stylesheet" type="text/css" />
    <script type="text/javascript">
        function myFunction() {
            $("#contraseña_incorrecta").modal('show');
        }
    </script>
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="server">
    <div style="text-align:center; background-color: #ffffff; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);">
        <asp:Label ID="lbl_passvieja" runat="server" Text="Contraseña actual: " CssClass="labels"></asp:Label>
        <asp:TextBox ID="txt_passvieja" runat="server" TextMode="Password" CssClass="textbox" AutoPostBack="true" BackColor="#efefef" OnTextChanged="txt_passvieja_TextChanged"></asp:TextBox>
        <br />
        <br />
        <asp:Label ID="lbl_passwordnueva" runat="server" Text="Nueva contraseña: " CssClass="labels"></asp:Label>
        <asp:TextBox ID="txt_passwordnueva" TextMode="Password" runat="server" AutoPostBack="true" BackColor="#efefef" OnTextChanged="txt_passwordnueva_TextChanged"></asp:TextBox>
        <br />
        <br />
        <asp:Label ID="lbl_confirmar" runat="server" Text="Confirme nueva contraseña: " CssClass="labels"></asp:Label>
        <asp:TextBox ID="txt_confirmar" TextMode="Password" runat="server" AutoPostBack="true" BackColor="#efefef" OnTextChanged="txt_confirmar_TextChanged"></asp:TextBox>
        <br />
        <br />
        <asp:Button ID="btn_cambiar" runat="server" Text="Cambiar contraseña" AutoPostBack="true" OnClick="btn_cambiar_Click" />
    </div>
    <div id="contraseña_incorrecta" class="modal fade" role="dialog">
        <div class="modal-dialog">
            <!-- Modal content-->
            <div class="modal-content">
                <div class="modal-header">
                    <button type="button" class="close" data-dismiss="modal">&times;</button>
                    <h4 class="modal-title"><asp:Label ID="lbl_header" runat="server"></asp:Label></h4>
                </div>
                <div class="modal-body">
                    <p><asp:Label ID="lbl_body" runat="server"></asp:Label></p>
                </div>
                <div class="modal-footer">
                    <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
                </div>
            </div>
        </div>
    </div>
</asp:Content>

我发现我的代码出了什么问题,并且是当Textmode设置为“ password”时,ASP会自动删除该Textbox中的所有文本。 为了解决这个问题,我要做的是:

string pass = txt_password.Text;
txt_password.Attributes.Add("value", pass);

我在结束TextChanged事件之前添加了这两行代码,因此,即使执行回发,也不会删除我的文本。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM