How To Use Vibration API In Your Website

Haptic Feedback in Your Website


2 min read

How To Use Vibration API In Your Website

Hello everyone ๐Ÿ‘‹

In this article, we will see how can we use Vibration API in our websites.

We can use the Vibration API to provide haptic or vibration feedback to the user using the website for their actions.

Most modern mobile devices include vibration hardware, which lets software code provide physical feedback to the user by causing the device to shake. So this API works well with mobile devices only and targeted for the same.

The Vibration API allows the web apps to access the vibration hardware if it exists.

Implementation ๐Ÿ‘จโ€๐Ÿ’ป

Let's explore the API.

We can access the API from the browser's window.navigator object.

Check Vibration API Support

It is always a good idea to check for API support.

if (Boolean(window.navigator.vibrate)) {
    // It Supports
  • vibrate is a method that is responsible for the vibration.
  • It expects one argument.

Argument is a number or an array of numbers for a series of vibrations. Those numbers are considered as milliseconds.

If the method was unable to vibrate because of invalid parameters, it will return false else it returns true.

Single Vibration ๐Ÿ“ณ

For a single vibration, we can pass a single number directly or in an array.

// Will vibrate the device for 500ms

// Same as the above line

Pattern Vibration ๐Ÿ“ณ ๐Ÿ“ณ ๐Ÿ“ณ

To vibrate the device in a pattern, we can pass an array of numbers.

Even indices numbers are responsible for the vibration and odd indices numbers will delay that much millisecond before the next vibration.

// Vibrate for 500ms, Wait for 200ms, Vibrate for 800ms
window.navigator.vibrate([500, 200, 800]);

Cancelling Vibrations

To cancel an ongoing vibration pattern, we need to pass a 0 or an empty array or an array containing all zeroes to the vibrate method.


Fun Example โœจ

Vibrate SOS in morse code.


Working only on Chrome Android.

Sample Code | Live Link

Thank you for reading ๐Ÿ™

If you enjoyed this article or found it helpful, give it a thumbs-up ๐Ÿ‘

Feel free to connect ๐Ÿ‘‹

Twitter | Instagram | LinkedIn

Did you find this article valuable?

Support Bibek Kakati by becoming a sponsor. Any amount is appreciated!