Skip to main content

Quick Start


party.js is a JavaScript library intended to provide customizeable particle effects to browser environments. To ensure a convenient development process, the library is written in TypeScript, and compiled for both Node.js (tsc) and browsers (webpack).

The goal is to provide users a more fun and charming experience while browsing/interacting with websites.


The library is intended to only work in browser-like environments, where a global document and window are both present. If either of those does not exist, the initialization will fail.


If you are using a package-managed environment, you can also install the latest version via npm.

npm install party-js# oryarn add party-js

You can then either import or require it.

import party from "party-js";// orconst party = require("party-js");



The library ships with pre-made template effects, to ensure you can get some effects working without having to spend hours tweaking every setting yourself. If you do want to make your own effects from scratch, scroll down to the custom effects section.

As an example, we will implement the confetti effect when a button is clicked.

<div class="button" onmousedown="party.confetti(this)">Click me!</div>

This is the simplest way to play the effect. Templated effects offer additional customizeability via option overrides, best explained in the following (interactive!) code snippet.

party.confetti(runButton, {    count: party.variation.range(20, 40),});
You can use the following objects in this codeblock: party, mouseEvent, codeblock, runButton.

The party.range(...) method is a variation method, used to make every instance of the effect unique, in this case by varying the amount of confetti emitted.

Custom effects#

If you want to have even more control over the effects that are played, you can completely customize the emitted particles. To ensure you have a good understanding on how customization in the library works, I recommend that you look at the documentation on variations and shapes first. Then, take a look at custom effects - these guide you through creating your own effects.