The Observer class is used to observe and manage changes to an object. It allows for tracking modifications to nested properties, emitting events on changes, and maintaining state consistency. This is particularly useful in applications where state management and change tracking are critical, such as in data-driven interfaces or collaborative applications.

const data = {
name: 'John',
age: 30,
address: {
city: 'New York',
zip: '10001'
}
};

const observer = new Observer(data);

observer.on('name:set', (newValue, oldValue) => {
console.log(`Name changed from ${oldValue} to ${newValue}`);
});

observer.set('name', 'Jane'); // Logs: Name changed from John to Jane

Hierarchy (View Summary)

Constructors

  • Creates a new Observer instance.

    Parameters

    • Optionaldata: object

      The initial data to observe.

    • options: {
          latestFn?: Function;
          parent?: Observer;
          parentField?: any;
          parentKey?: any;
          parentPath?: string;
          pathsWithDuplicates?: string[];
      } = {}

      Additional options for the observer.

    Returns Observer

Accessors

  • get suspendEvents(): boolean
  • Gets whether events are suspended.

    Returns boolean

  • set suspendEvents(value: boolean): void
  • Sets whether events are suspended. If true, the observer will not emit events when values are set.

    Parameters

    • value: boolean

    Returns void

Methods

  • Emits the specified event, executing all registered listeners for that event with the provided arguments. If events are suspended, the emit operation will be ignored.

    Parameters

    • name: string

      The name of the event to emit.

    • Optionalarg0: any

      The first argument to pass to the event listeners.

    • Optionalarg1: any

      The second argument to pass to the event listeners.

    • Optionalarg2: any

      The third argument to pass to the event listeners.

    • Optionalarg3: any

      The fourth argument to pass to the event listeners.

    • Optionalarg4: any

      The fifth argument to pass to the event listeners.

    • Optionalarg5: any

      The sixth argument to pass to the event listeners.

    • Optionalarg6: any

      The seventh argument to pass to the event listeners.

    • Optionalarg7: any

      The eighth argument to pass to the event listeners.

    Returns Observer

    The current instance for chaining.

    // Register an event listener
    events.on('testEvent', (arg1, arg2) => {
    console.log('Event triggered with arguments:', arg1, arg2);
    });

    // Emit the event
    events.emit('testEvent', 'value1', 'value2');

    // Emit the event with more arguments
    events.emit('testEvent', 'value1', 'value2', 'value3', 'value4');
  • Parameters

    • path: string

      Path to the value.

    • raw: boolean = false

      Retrieve the observer object without converting it to JSON.

    Returns any

    The value at the specified path.

  • Query whether the object has the specified property.

    Parameters

    • path: string

      Path to the value.

    Returns boolean

    Returns true if the value is present and false otherwise.

  • Parameters

    • path: string

      Path to the value.

    • value: any

      Value to insert.

    • Optionalind: number

      Index to insert the value at.

    • silent: boolean = false

      If true, the insert event will not be emitted.

    • remote: boolean = false

      State value passed to the set event used to disable remote event emission.

    Returns boolean

    Returns true if the value was successfully inserted and false otherwise.

  • Parameters

    • path: string

      Path to the value.

    • indOld: number

      Index of the value to move.

    • indNew: number

      Index to move the value to.

    • silent: boolean = false

      If true, the move event will not be emitted.

    • remote: boolean = false

      State value passed to the set event used to disable remote event emission.

    Returns boolean

    Returns true if the value was successfully moved and false otherwise.

  • Registers an event listener for the specified event name. If the event is emitted, the callback function is executed with up to 8 arguments.

    Parameters

    • name: string

      The name of the event to listen for.

    • fn: HandleEvent

      The callback function to be executed when the event is emitted.

    Returns EventHandle

    An EventHandle object that can be used to unbind the event listener.

    // Register an event listener
    events.on('testEvent', (arg1, arg2) => {
    console.log('Event triggered with arguments:', arg1, arg2);
    });

    // Emit the event
    events.emit('testEvent', 'value1', 'value2');
  • Registers a one-time event listener for the specified event name. The callback function is executed the next time the event is emitted, and then automatically unbound.

    Parameters

    • name: string

      The name of the event to listen for.

    • fn: HandleEvent

      The callback function to be executed once when the event is emitted.

    Returns EventHandle

    An EventHandle object that can be used to unbind the event listener before it is triggered.

    // Register a one-time event listener
    events.once('testEvent', (arg1, arg2) => {
    console.log('Event triggered once with arguments:', arg1, arg2);
    });

    // Emit the event
    events.emit('testEvent', 'value1', 'value2'); // The callback will be called and then unbound.

    // Emit the event again
    events.emit('testEvent', 'value1', 'value2'); // The callback will not be called this time.
  • Parameters

    • path: string

      Path to the value.

    • ind: number

      Index of the value.

    • silent: boolean = false

      If true, the remove event will not be emitted.

    • remote: boolean = false

      State value passed to the set event used to disable remote event emission.

    Returns boolean

    Returns true if the value was successfully removed and false otherwise.

  • Parameters

    • path: string

      Path to the value.

    • value: any

      Value to remove.

    • silent: boolean = false

      If true, the remove event will not be emitted.

    • remote: boolean = false

      State value passed to the set event used to disable remote event emission.

    Returns boolean

    Returns true if the value was successfully removed and false otherwise.

  • Parameters

    • path: string

      Path to the property in the object.

    • value: any

      Value to set.

    • silent: boolean = false

      If true, the change will not be recorded in history.

    • remote: boolean = false

      State value passed to the set event used to disable remote event emission.

    • force: boolean = false

      If true, the value will be set even if it is the same as the current value.

    Returns boolean

    Returns true if the value was successfully set and false otherwise.

  • Unbinds an event listener for the specified event name. If a callback function is provided, only that specific listener is removed. If no callback is provided, all listeners for the event are removed. If no event name is provided, all listeners for all events are removed.

    Parameters

    • Optionalname: string

      The name of the event to unbind. If not provided, all events are unbound.

    • Optionalfn: HandleEvent

      The specific callback function to remove. If not provided, all listeners for the event are removed.

    Returns Observer

    The current instance for chaining.

    // Register an event listener
    const callback = (arg1, arg2) => {
    console.log('Event triggered with arguments:', arg1, arg2);
    };
    events.on('testEvent', callback);

    // Unbind the specific event listener
    events.unbind('testEvent', callback);

    // Unbind all listeners for a specific event
    events.unbind('testEvent');

    // Unbind all listeners for all events
    events.unbind();
  • Parameters

    • path: string

      Path to the value.

    • silent: boolean = false

      If true, the change will not be recorded in history.

    • remote: boolean = false

      State value passed to the set event used to disable remote event emission.

    Returns boolean

    Returns true if the value was successfully unset and false otherwise.