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 🙏

© 2025 – Pkg Stats / Ryan Hefner

attributejs

v2.0.0

Published

AttributeJS is a 1KB library alternative to Custom Elements v1 with the same modern API

Downloads

5

Readme

AttributeJS

Define custom attributes on standard HTML elements and use the same Custom Elements v1 API you know and love to encapsulate your functionality.

Install

Install via NPM or Yarn

npm i attributejs --save

Import as an ES module

import { Attribute } from 'attributejs';

Once imported, the Attribute class exposes the static method define which can be used to define custom attributes.

Example

<button my-button>My button</button>
import { Attribute } from 'attributejs';

class MyButton {
  constructor() {
  }

  connectedCallback() {
    console.log(`
      The 'my-button' attribute has been added to an element and 
      is now binded to said element.
    `);
    this.setBackground();
  }

  disconnectedCallback() {
    console.log(`
      The 'my-button' attribute has been removed from the binded element,
      or the binded element has been removed from the DOM.
    `);
  }

  setBackground() {
    // Custom method
    this.element.style.backgroundColor = `blue`;
  }
}

Attribute.define({
  ['my-button']: MyButton
});

API

The AttributeJS library exposes a very similar API to the Custom Elements v1 spec.

Classes that are defined are given lifecycle callbacks to which you may respond appropriately with your corresponding code.

Defining custom attributes

To define a custom attribute, import the Attribute class and use the define method, passing an object as an argument. The object key should be the attribute name. The object value should be the custom class declaration. Many classes can be passed within the object to the define method.

Attribute.define({ 
  ['my-button']: MyButton, 
  ['my-second-button']: MySecondButton,
  ...
});

Lifecycle callbacks

constructor

The constructor lets you set up class properties and methods, just like a regular ES class. Note: The element property is not yet exposed to the class instance.

connectedCallback

The connectedCallback method is invoked when the element is first binded to the attribute.

You are then able to manipulate the host element via the element property.

connectedCallback() {
  this.element.innerHTML = `My innerHTML has changed!`;
}

disconnectedCallback

The disconnectedCallback method is invoked either when the element is removed from the DOM, or the custom attribute is removed from the element.

The element is still available via the element property within this method and any necessary clean up can be done.

disconnectedCallback() {
  this.element.removeEventListener(`click`, this.myClickHandler);
}

Properties

element

this.element refers to the element containing the custom attribute.

Motivation

Safari have declined allowing developers to extend native elements with the proposed is="my-element" attribute, which has created complications for the Custom Elements v1 project.

The AttributeJS library adds support for extending native elements, whilst keeping the Custom Elements v1 API intact.

License

MIT License