White Arrow icon
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:

Share:

Destin's Youtube channel Smarter Every Day is one of my favourite places on the web.

Might also interest you:

Symbol in RichText

Cloneable
CMS
Code

Insert a symbol element into a RichText. On a static or dynamic page.

Read more
White Arrow icon

Round Scroll Indicator / Progress Bar

Cloneable
Interactions
Animation

A round scroll indicator mad with Webflow elements and interactions

Read more
White Arrow icon

Pass Parameters

Cloneable
Code

Pass input fields parameters and add them to the destination URL.

Read more
White Arrow icon