Skip to content

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.

License

Notifications You must be signed in to change notification settings

Infinitode/BlurJS

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

BlurJS 1.3

GitHub license GitHub stars GitHub issues JSDelivr monthly downloads

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.

Changes in Version 1.3

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.

Changes in Version 1.2

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.

Changes in Version 1.1:

  1. Moved the for loop to loop per element, improving stability and performance.
  2. Created implementations for interactions with blur elements using the blur-interaction attribute.
  3. Updated the code to also have attributes for controlling pointer events and user selection.

Getting Started

Installation

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.

How to use BlurJS

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.

Available properties

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 to true 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 the blur-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 from scroll (triggers animation when in viewport), click (toggles animation state when clicked) or hover (toggles playing state based on hover events). no default assigned

Note

View the official documentation for more information...

Usage examples

Here follows a couple of basic usage examples for BlurJS.

1. Controlling Width and Height

<div class="blur" blur-width="50px" blur-height="50px">

2. Background / Color

<div class="blur" blur-background="#5d17eb">

3. Border Radius

<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.

License

BlurJS is licensed under a modified MIT license, please view the license file for more information.

Contributions

All contributions are welcome! You can get started by opening a request on Github. Help us make BlurJS better for everyone!

Releases

No releases published

Packages

No packages published