views:

816

answers:

5

How can I make an event that is raised when a variable or property is changed (or can I just put the code I would put in an event in the Set section of a property?

+3  A: 

Yes, the best (if not the only) way of doing this is to completely hide the actual variable (make it Private) and expose it via a Property which fires events whenever the setter is used.

I do this regularly, but I've found that it's important to NOT raise the event if the new value is similar to the old value. This both eliminates unnecessary function calls and sometimes prevents recursive events.

David Rutten
Great point about not raising the event on a non-change -- I've seen this cause problems with WPF data binding.
itowlson
There often isn't any actual need for an event, remember that you can do almost anything within a setter.
Paul Creasey
what do you mean if they are similar?
Jonathan
@Jonathan, let's say you have a Property that links to a Private integer called m_index. In the setter, *before* you raise the event, add this line: If (value = m_index) Then Return
David Rutten
A: 

The canonical event for this is the PropertyChanged event, which is defined in the INotifyPropertyChanged interface. You can raise this from your property setters. (Note that VB.NET will not raise the event for you: you must include the code to raise it.)

If the code you want to run on a change is logically part of your class (e.g. updating a customer status when the balance changes) then it is appropriate to put this in the property setter rather than in an event handler. Event handlers are for when external code needs to know about changes, e.g. to update the UI in response to the customer status changing.

itowlson
A: 

Take a look at this example implementation of the INotifyPropertyChanged interface, this is the standard method used for this functionality. The important parts are the NotifyPropertyChanged method and the code inside the property set handlers.

Rory
+1  A: 

From the MSDN library entry INotifyPropertyChanged.PropertyChanged Event:

Public Class DemoCustomer
    Implements INotifyPropertyChanged

    Private customerNameValue As String = String.Empty

    Public Event PropertyChanged As PropertyChangedEventHandler _
        Implements INotifyPropertyChanged.PropertyChanged

    Private Sub NotifyPropertyChanged(ByVal info As String)
        RaiseEvent PropertyChanged(Me, New PropertyChangedEventArgs(info))
    End Sub

    Public Property CustomerName() As String
        Get
            Return Me.customerNameValue
        End Get

        Set(ByVal value As String)
            If Not (value = customerNameValue) Then
                Me.customerNameValue = value
                NotifyPropertyChanged("CustomerName")
            End If
        End Set
    End Property
End Class
Aviad P.
A: 

How do i handle the property changed event?

Basically i am looking to put a trigger on an event, and when the value is anything but Null (NOTHING), or same value, then i have another internal variable i want to set.

Similar to the HasValue variable.

Im using this HasValue as a checksum to see if i need to work any other magic

John