自定义事件处理程序正在重复

时间:2013-07-23 04:41:16

标签: c# .net event-handling windows-phone-8

我的自定义事件处理程序在登录完成时执行,它会自行重复。

重复一遍,我的意思是在第一次事件发生时,处理程序只执行一次。但是,当事件第二次发生时,处理程序执行2次!当事件第三次发生时,处理程序执行3次,依此类推。

这是我的代码。我忽略了什么?

订阅活动

SignIn signIn = new SignIn();
signIn.Login_Complete += new SignIn.EventHandler(recieveLoginResult);
pb.IsVisible = true;
signIn.Login(control.username.Text, control.password.Password);

事件

class SignIn
{
    public event EventHandler Login_Complete;
    public event EventHandler Logout_Complete;
    public event EventHandler Signup_Complete;
    public delegate void EventHandler(Object sender, String message);

...

    public void Login(String username, String password)
    {
        Dictionary<string, object> parameters = new Dictionary<string, object>();
        parameters.Add("user", username);
        parameters.Add("pass", password);

        PostClient client = new PostClient(parameters);
        client.DownloadStringCompleted += (senders, ex) =>
            {
                if (ex.Error == null)
                {
                    //Process the result...
                    Login_Complete(this, ex.Result);
                }
                else
                {
                    Login_Complete(this, "An error occurred. The details of the error: " + ex.Error);
                }
            };
        client.DownloadStringAsync(new Uri("(SOME URL HERE)", UriKind.Absolute));
    }

事件处理程序

    private void recieveLoginResult(object sender, String loginResult)
    {
        SignIn signin = new SignIn();
        signin.Login_Complete -= recieveLoginResult;

        //Check if the result is numeric or not.
        bool textIsNumeric = true;
        try
        {
            int.Parse(loginResult);
        }
        catch
        {
            textIsNumeric = false;
        }

        if (textIsNumeric == true)
        {
            //Logged in successfully.
            popup.IsOpen = false;
            loginName.Text = control.username.Text;
            sessionID = int.Parse(loginResult);
        }
        else
        {
            //Did not log in successfully.
            MessageBox.Show(loginResult, "Error", MessageBoxButton.OK);
        }

        pb.IsVisible = false;
    }

2 个答案:

答案 0 :(得分:2)

订阅前取消订阅。

SignIn signIn = new SignIn();
signIn.Login_Complete -= recieveLoginResult;
signIn.Login_Complete += recieveLoginResult;
pb.IsVisible = true;
signIn.Login(control.username.Text, control.password.Password);

如果它尚未订阅,它将不会执行任何操作,但如果是,它将确保您没有订阅两次。至于你的另一个问题,你可以通过删除上面那些取消订阅的其他代码行来解决它。

答案 1 :(得分:0)

确保从正在订阅的同一对象中删除事件处理程序。看起来您正在创建要从该事件取消订阅的新对象。

SignIn signIn = new SignIn();
 signIn.Login_Complete += new SignIn.EventHandler(recieveLoginResult);


 SignIn signin = new SignIn(); // this could be the problem...***
    signin.Login_Complete -= recieveLoginResult;