BlurJS is a lightweight JavaScript library for creating blurred effects on HTML elements. Easily integrate blurred elements into your web projects with simple HTML attributes.
Note
Older versions of BlurJS are not maintained, and are not recommended for use. We only maintain main
, which is the latest stable release of BlurJS.
BlurJS now supports using multiple animations in one single element. You can combine animations and change their easing, duration, and repetitions to create unique and fun interactions/animations. New blur-{animation-type}-timing
parameter for controlling easing during animations.
Pointer events and user selection is now available through BlurJS parameters. You can trigger animation effects dynamically using the new blur-interaction
parameter. This will enable you to make custom interactions using very little effort.
- Moved the for loop to loop per element, improving stability and performance.
- Created implementations for interactions with blur elements using the
blur-interaction
attribute. - Updated the code to also have attributes for controlling pointer events and user selection.
You can include BlurJS in your project by downloading it from this repository and linking it to your HTML file. Alternatively, use the CDN link for faster loading:
Minified Version
<script src="https://cdn.jsdelivr.net/gh/Infinitode/BlurJS@main/dist/blur.min.js"></script>
Normal Version
<script src="https://cdn.jsdelivr.net/gh/Infinitode/BlurJS@main/dist/blur.js"></script>
Important
BlurJS should be placed in the body
element of your HTML file, after all the blur elements, not in the head
element.
You can use BlurJS in an HTML file. It will automatically detect all elements with a class of blur
.
Note
The parent element in which the blur is placed must have it's position set to relative
.
There are several available properties that come with BlurJS, these include (include as attributes in the element, see example below):
blur-width
: Sets the width of the blur.default 50px
blur-height
: Sets the height of the blur.default 50px
blur-amount
: Sets the amount of blur.default 25px
blur-background
: Sets the color or background of the blur (gradients can also be used).default red
blur-z-index
: Sets the Z Index of the blur.default 99
blur-top
: Positions the blur from the top.no default assigned
blur-left
: Positions the blur from the left.no default assigned
blur-right
: Positions the blur from the right.no default assigned
blur-bottom
: Positions the blur from the bottom.no default assigned
blur-border-radius
: Changes the blur border radius.default 5rem 2rem 5rem 50%
blur-grain
: Must be set totrue
in order to work. Sets the blur to a grainy texture.no default assigned
blur-scale
: The value to scale to. If present triggers a scale animation to that value.no default assigned
blur-scale-duration
: Optional duration value for the scale animation.no default assigned
blur-scale-repetitions
: Optional repetitions value for the scale animation.no default assigned
blur-scale-timing
: Optional timing value for the scale animation.default linear
blur-translate-x
: The value to translate on the x-axis. If present triggers a translation animation to that value.no default assigned
blur-translate-x-duration
: Optional duration value for the translation animation.no default assigned
blur-translate-x-repetitions
: Optional repetitions value for the translation animation.no default assigned
blur-translate-x-timing
: Optional timing value for the translation animation.default linear
blur-translate-y
: The value to translate on the y-axis. If present triggers a translation animation to that value.no default assigned
blur-translate-y-duration
: Optional duration value for the translation animation.no default assigned
blur-translate-y-repetitions
: Optional repetitions value for the translation animation.no default assigned
blur-translate-y-timing
: Optional timing value for the translation animation.default linear
blur-opacity
: The value to animate on the opacity property. If present triggers a opacity animation to that value.no default assigned
blur-opacity-duration
: Optional duration value for the opacity animation.no default assigned
blur-opacity-repetitions
: Optional repetitions value for the opacity animation.no default assigned
blur-opacity-timing
: Optional timing value for the opacity animation.default linear
blur-animate
: The value to transition to. Transitions from theblur-amount
value and this value. If present triggers a blur animation to that value.no default assigned
blur-animate-duration
: Optional duration value for the blur animation.no default assigned
blur-animate-repetitions
: Optional repetitions value for the blur animation.no default assigned
blur-animate-timing
: Optional timing value for the blur animation.default linear
blur-interaction
: Optional value for animation triggers, choose fromscroll
(triggers animation when in viewport),click
(toggles animation state when clicked) orhover
(toggles playing state based on hover events).no default assigned
Note
View the official documentation for more information...
Here follows a couple of basic usage examples for BlurJS.
<div class="blur" blur-width="50px" blur-height="50px">
<div class="blur" blur-background="#5d17eb">
<div class="blur" blur-border-radius="50%">
These examples only detail the basic usage of BlurJS, BlurJS is directly connected to CSS properties, which allows for more advanced effects such as gradient blurs, animated blurs, shape blurs, etc. You can also create animated effects and interactions using BlurJS's attributes.
BlurJS is licensed under a modified MIT license, please view the license file for more information.
All contributions are welcome! You can get started by opening a request on Github. Help us make BlurJS better for everyone!