Event fires more and more times

前端 未结 4 2047
余生分开走
余生分开走 2020-12-06 18:40

I have a silverlight mvvm application that loads main view with 2 user controls loaded into 2 ContentControls, one with listbox showing items and other with edit button. Whe

相关标签:
4条回答
  • 2020-12-06 19:03

    You could define a private eventhandler delegate variable in your class and assign it in your constructor:

    private SaveButtonClickedHandler _handler;
    

    Assign the handler in your constructor:

    _handler = (s,e) => SaveData();
    this.globalEvents.OnSaveButtonClicked += _handler;
    

    Dispose:

    this.globalEvents.OnSaveButtonClicked -= _handler; 
    

    "SaveButtonClickedHandler" is pseudo-code/placeholder for whatever the name of the delegate should be.

    Hasanain

    0 讨论(0)
  • 2020-12-06 19:11

    You can't use lambdas when you want to unregister from events.

    this.globalEvents.OnSaveButtonClicked += (s, e) => SaveData(); 
    

    This will create one instance - let's call it instance A - of type EventHandler and add it as a handler.

    this.globalEvents.OnSaveButtonClicked -= (s, e) => SaveData(); 
    

    This will not remove instance A from the event but create a new instance - instance B - and tries to remove it from the event.

    To fix this problem, either create a little method or save that anonymous method in a field:

    class ViewModel
    {
    
        private EventHandler _saveButtonClickedHandler;
        // ...
    
        public ViewModel()
        {
            _saveButtonClickedHandler = (s, e) => SaveData();
            this.globalEvents.OnSaveButtonClicked += _saveButtonClickedHandler;
            // ...
        }
    
        public void Dispose()
        {
            this.globalEvents.OnSaveButtonClicked -= _saveButtonClickedHandler;
            // ...
        }
    
        // ...
    }
    
    0 讨论(0)
  • 2020-12-06 19:15
    this.globalEvents.OnSaveButtonClicked += (s, e) => SaveData();
    

    This line is being called multiple times so you are adding a new event handler every time.

    You need to either move that line to somewhere where it's only called once or change the event handler to:

    this.globalEvents.OnSaveButtonClicked += SaveData;
    
    public void SaveData(object sender, EventArgs e)  
    {  
        globalEvents.RaiseSaveData(EditedGuy);     
        this.globalEvents.OnSaveButtonClicked -= SaveData();
    }
    

    So you remove the event handler after dealing with it. This assumes that the handler will be added back next time you go into edit mode.

    0 讨论(0)
  • 2020-12-06 19:28

    You'll have to put in a proper event handler method that calls SaveData() and register/unregister that. Otherwise you try to unregister another "new" anonymous method instead of the original one you've registered, which you, because it is anonymous, cannot actually access anymore.

    public void SaveButtonClicked(object sender, EventArgs e)
    {
        SaveData();
    }
    
    this.globalEvents.OnSaveButtonClicked += SaveButtonClicked;
    
    this.globalEvents.OnSaveButtonClicked -= SaveButtonClicked;
    
    0 讨论(0)
提交回复
热议问题