npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

shelving-mock-event

v1.0.12

Published

Fully unit tested mock implementation of the browser Event API.

Downloads

125,904

Readme

Event mock

Build Status

Fully unit tested mock implementation of the browser Event API. Conforms as closely as possible to Event.

Mocked Event and EventTarget classes that conform to browser's Event API. Can be used to simulate events in server-side code for testing, or in other places where browser APIs are not available.

Supports the following functionality:

  • Event listeners, e.g. addEventListener() and removeEventListener()
  • Event handlers, e.g. target.onclick = function()
  • Event dispatch, e.g. dispatchEvent()
  • Parent heirarchy with bubbling (and capturing) like DOM elements
  • Stopping propagation with stopPropagation() and stopImmediatePropagation()
  • Preventing default with preventDefault()

Examples

Create an event target and dispatch events on it

This full example shows how you would create an EventTarget (with a parent EventTarget that events will bubble up to), and dispatch an Event on that target:

import { Event, EventTarget } from 'shelving-mock-event';

// Create targets.

	// Create a parent target.
	const parent = new EventTarget();

	// Create a target and pass in the parent target.
	// Allow `onclick` handler on the target.
	const target = new EventTarget(parent, ['click']); 

// Attach event listeners/handlers.
// Will be called in this order (as-per the event capturing/bubbling model).

	// Add event listener on parent.
	// Called during capturing phase, i.e. BEFORE listeners on the target.
	parent.addEventListener('click', () => { console.log('Called 1'); }, true);

	// Add event handler on target.
	target.onclick = (e) => { console.log('Called 2'); }
	
	// Add event listener on target.
	target.addEventListener('click', () => { console.log('Called 3'); });
	
	// Add event listener on parent target.
	// Called during bubbling phase, i.e. AFTER listeners on the target.
	parentTarget.addEventListener('click', () => { console.log('Called 5'); });

// Fire the event on the target.
target.dispatchEvent(new Event('click', { bubbles: true }));

Creating a custom event targets

EventTarget is not normally used directly, but is implemented by a specific class. Javascript ES6 classes make this easy as you can simply extend EventTarget:

// Create a custom Javascript class.
class MyThing extends EventTarget
{
	// Construct.
	constructor(parent)
	{
		// Call super() to initialise this.
		// Pass through any parent element.
		// Initialise `onclick` and `onboom` properties.
		super(parent, ['click', 'boom']);
	}
}

// Make a new MyThing.
const thing = new MyThing();

// Add a handler on the thing.
thing.onboom = () => { console.log('Called handler!'); }

// Add a listener on the thing.
thing.addEventListener('boom', () => { console.log('Called listener!'); });

// Dispatch event.
thing.dispatchEvent(new Event('boom'));

API

Event

new Event(type, { bubbles = false, cancelable = false })
Create a new event that can be dispatched on an event target. Conforms to the Event interface.

  • type (string)
    The name of the event, e.g. 'click', 'blur' or 'my-custom-event'

  • bubbles (boolean)
    Whether the event should bubble up to the parent EventTarget when dispatched. The default is false

  • cancellable (boolean)
    Whether the event can be cancelled. The default is false

Properties

  • Event.type (string)
    The name of the event, e.g. 'click', 'blur' or 'my-custom-event' (matches what was passed in to the constructor. Read only.

  • Event.cancellable (boolean)
    Whether this event can be cancelled or not (matches what was passed in to the constructor). Read only.

  • Event.bubbles (boolean)
    Whether this event will bubble or not (matches what was passed in to the constructor). Read only.

  • Event.target (boolean)
    A reference to the original event target the event was called on. Read only.

  • Event.currentTarget (boolean)
    A reference to the current target that this event is firing on. Read only.

  • Event.eventPhase (constant)
    The current phase of the event. Read only. Will be one of the following:

    • Event.NONE
    • Event.CAPTURING_PHASE
    • Event.AT_TARGET
    • Event.BUBBLING_PHASE
  • Event.timeStamp (number)
    The time this event was created, in milliseconds. Read only.

  • Event.defaultPrevented (boolean)
    Whether or not Event.preventDefault() has been called on the event. Read only.

Methods

  • Event.preventDefault()
    Cancels the event (if it is cancelable).

  • Event.stopPropagation()
    Stops the propagation (bubbling or capturing) of events on targets further along in the event dispatch order.

  • Event.stopImmediatePropagation()
    Stops the propagation (bubbling or capturing) of events on targets further along in the event dispatch order and any further events on the current target.

EventTarget

new EventTarget(parent = undefined, handlers = [])
An object which can have events dispatched on it. Conforms to the EventTarget interface.

  • parent (EventTarget)
    The parent element for this element that events will bubble up to (if specified)

  • handlers (array of strings)
    Allow event handlers on this target. Handlers that are not explicitly named in the constructor will not be called when an event is dispatched. Handlers must be functions. Do not include 'on' at the start of the handler name.

Properties

  • EventTarget.onclick (function)
    Set this property to a function to be called when an event is dispatched. Handler names must be explicitly specified in the constructor. If handler is not a function then TypeError will be thrown.

Methods

  • EventTarget.addEventListener(type, callback, capturing = false)
    Add an event listener to an event target. Event listeners are callback functions that are called when the named event is dispatched on the event target or one of its children.

    • type (string)
      The name of the event to listen for, e.g. 'click', 'blur' or 'my-custom-event'

    • callback (function)
      The callback function that gets called when type events are dispatched on this target. The callback function will receive the following arguments:

      • event
        The Event object that was dispatched on the event target.
    • capturing (boolean)
      Whether the listener should be attached to the capturing phase (before listeners on the target) or the bubbling phase (after listeners on the target). The default is false (bubbling phase).

  • EventTarget.removeEventListener(type, callback, capturing = false)
    Remove a specific event listener from an event target.

    • type (string)
      The name of the event you wish to stop listening for, e.g. 'click', 'blur' or 'my-custom-event'

    • callback (function)
      The callback function you wish to remove. Must be a reference to the same callback function that was added.

    • capturing (boolean)
      Must match the capturing setting that was used when the event was added.