Skip to content

A lightweight javascript file to create a cool 3d hover effect

Notifications You must be signed in to change notification settings

nielsvanrijn/3dGradient

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 

Repository files navigation

3dGradient

A lightweight javascript file to create a cool 3d hover effect

Installation

Include the 3d Gradient script in your html head

<script defer type="text/javascript" src='3dGradient.js'></script>

In the element that your want the effect add these styles

background: linear-gradient(135deg, #FF7A76 0%, #ffe076 100%);
will-change: transform;
transform-style: preserve-3d;
transform: perspective(300px) rotateX(0deg) rotateY(0deg);
-webkit-transform: perspective(300px) rotateX(0deg) rotateY(0deg);
transition: 400ms cubic-bezier(0.03, 0.98, 0.52, 0.99);
-webkit-transition: 400ms cubic-bezier(0.03, 0.98, 0.52, 0.99);

You can change the linear-gradient to whatever you would like it to be

Done!

If you want the child elements of the main element to change perspective too, use these styles

transform: scale(0.8333) translateZ(50px);
-webkit-transform: scale(0.8333) translateZ(50px);

Usage

To use the script just add A class to whatever HTMLelement you want, and specify it in the script

In this example I have four elements that get the effect

<div class="flexrow">
    <div class="card">
        <h1>A</h1>
    </div>
    <div class="card">
        <h1>B</h1>
    </div>
    <div class="card">
        <h1>C</h1>
    </div>
    <div class="card">
        <h1>D</h1>
    </div>
</div>

The default HTMLelment and class combination is div.card, but you can change it in whatever you want! On line 6 of the script pass your HTMLelement and class cobination in the querySelectorAll

document.querySelectorAll('div.card').forEach(function(elem) {...}

Enjoy!

About

A lightweight javascript file to create a cool 3d hover effect

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published