Back to all Elements

Cursor Blend

A few short lines of code, to replace the pointer with an interactive color element.

1. Giving an element a mix-blend-mode property so it will change it's color by the color of the element behind.

We start by creating a div and giving it the class .cursor and these properties:

  • width: 30px
  • height: 30px
  • margin-top: -15px
  • margin-left: -15px
  • position: absolute
  • z-index: 9999
  • background: white
  • border-radius: 30px

Now we need to add a bit of code for that to work well.

1st part is making sure we won't get horizontal scroll bar once the element (pointer) is outside of the viewport.

2nd part is giving the .cursor class the mix-blend-mode and making it "transparent" so any clicks of the actual pointer will "go through" to the element below.

<style>

 

 ‍ html,

 body {

   max-width: 100%;

   overflow-x: hidden;

 }

 .cursor {

   mix-blend-mode: difference;

   pointer-events: none;

 }

</style>

Copy

2. Replacing the pointer with the new element.

Now we need edit the body TAG to make the cursor "disappear"

Webflow's Style panel, body TAG selected

And now all that is left to do is to "glue" the .cursor element to the mouse movements with a bit of JavaScript

<script>

 ‍

 var $cursor = $('.cursor');‍

 

 function moveCursor(e) {

   $cursor.css({

     "top": e.pageY,

     "left": e.pageX

   });

 }‍

 

 $(window).on('mousemove', moveCursor);‍

</script>

Copy

Preview:

When your bath soap bar gets too small to use, don't throw it away! open the next bar, and when you finish showering, stick the small old bar to the back of the new bar. Onces they both dry, they will become one.

Might also interest you:

Thick Underline

Cloneable
Design
Tricks

An editable thick underline for your Headlines

Read more

ToDo List

Cloneable
Code

A todo list, created with JavaScript collected through the internet... ;)

Read more

Modal Lottie Transition

Cloneable
Design
Interactions

A full screen close/open animation with lottie

Read more