Skip to content

Instantly share code, notes, and snippets.

@vielhuber
Last active April 23, 2023 19:12
Show Gist options
  • Save vielhuber/cd25828346243010f4b0af7af10720b7 to your computer and use it in GitHub Desktop.
Save vielhuber/cd25828346243010f4b0af7af10720b7 to your computer and use it in GitHub Desktop.
cursor effect #css #js
<!DOCTYPE html>
<html lang="de">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=5, minimum-scale=1" />
<title>.</title>
<script>
document.addEventListener('DOMContentLoaded', () => {
document.body.insertAdjacentHTML('beforeend', '<div class="smooth-cursor"></div>');
let smoothCursor = document.querySelector('.smooth-cursor');
let smoothCursorVisibility = () => {
if (!('ontouchstart' in window || navigator.maxTouchPoints > 0 || navigator.msMaxTouchPoints > 0)) {
document.documentElement.classList.add('smooth-cursor-active');
} else {
document.documentElement.classList.remove('smooth-cursor-active');
}
};
window.addEventListener('resize', () => {
smoothCursorVisibility();
});
smoothCursorVisibility();
window.addEventListener('mousemove', e => {
let mouseX = e.clientX,
mouseY = e.clientY;
smoothCursor.style.left = mouseX + 'px';
smoothCursor.style.top = mouseY + 'px';
});
let highlightSelector = '.smooth-cursor-highlight, a';
document.addEventListener('mouseover', e => {
if (e.target.closest(highlightSelector)) {
document.documentElement.classList.add('smooth-cursor-big');
}
if (e.target.closest('.smooth-cursor-ignore, iframe')) {
document.documentElement.classList.remove('smooth-cursor-active');
}
});
document.addEventListener('mouseout', e => {
if (e.target.closest(highlightSelector)) {
document.documentElement.classList.remove('smooth-cursor-big');
}
if (e.target.closest('.smooth-cursor-ignore, iframe')) {
smoothCursorVisibility();
}
});
document.addEventListener('click', e => {
if (e.target.closest(highlightSelector)) {
document.documentElement.classList.remove('smooth-cursor-big');
}
});
document.documentElement.addEventListener('mouseleave', () => {
document.documentElement.classList.add('smooth-cursor-hidden');
});
document.documentElement.addEventListener('mouseenter', () => {
document.documentElement.classList.remove('smooth-cursor-hidden');
});
});
</script>
<style>
*
{
box-sizing: border-box;
margin: 0;
padding: 0;
}
html {
background-color:#fff;
}
:root {
--cursor-size: 6rem;
}
.smooth-cursor {
height: var(--cursor-size);
width: var(--cursor-size);
background-color: #fff;
color: #fff;
border-radius: 50%;
mix-blend-mode: exclusion;
pointer-events: none;
position: fixed;
transform: translate(calc(-1 * var(--cursor-size) / 2), calc(-1 * var(--cursor-size) / 2)) scale(0.33) rotate(90deg);
transition: transform 0.3s cubic-bezier(0.47, 1.64, 0.41, 0.8);
z-index: 2147483647;
opacity: 0;
top: calc(-1 * var(--cursor-size));
left: calc(-1 * var(--cursor-size));
}
html.smooth-cursor-active .smooth-cursor {
opacity: 1;
}
html.smooth-cursor-big .smooth-cursor {
transform: translate(calc(-1 * var(--cursor-size) / 2), calc(-1 * var(--cursor-size) / 2)) scale(1) rotate(90deg);
}
html.smooth-cursor-hidden .smooth-cursor {
transform: translate(calc(-1 * var(--cursor-size) / 2), calc(-1 * var(--cursor-size) / 2)) scale(0) rotate(90deg);
}
</style>
</head>
<body>
<div class="container">
<p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium quis, sem. Nulla consequat massa quis enim. Donec pede justo, fringilla vel, aliquet nec, vulputate eget, arcu. In enim justo, rhoncus ut, imperdiet a, venenatis vitae, justo. Nullam dictum felis eu pede mollis pretium. Integer tincidunt. Cras dapibus. Vivamus elementum semper nisi. Aenean vulputate eleifend tellus.</p>
<p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium quis, sem. Nulla consequat massa quis enim. Donec pede justo, fringilla vel, aliquet nec, vulputate eget, arcu. In enim justo, rhoncus ut, imperdiet a, venenatis vitae, justo. Nullam dictum felis eu pede mollis pretium. Integer tincidunt. Cras dapibus. Vivamus elementum semper nisi. Aenean vulputate eleifend tellus.</p>
<p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium quis, sem. Nulla consequat massa quis enim. Donec pede justo, fringilla vel, aliquet nec, vulputate eget, arcu. In enim justo, rhoncus ut, imperdiet a, venenatis vitae, justo. Nullam dictum felis eu pede mollis pretium. Integer tincidunt. Cras dapibus. Vivamus elementum semper nisi. Aenean vulputate eleifend tellus.</p>
<p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. <a href="#" class="smooth-cursor-highlight">Lorem ipsum dolor sit amet</a>, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium quis, sem. Nulla consequat massa quis enim. Donec pede justo, fringilla vel, aliquet nec, vulputate eget, arcu. In enim justo, rhoncus ut, imperdiet a, venenatis vitae, justo. Nullam dictum felis eu pede mollis pretium. Integer tincidunt. Cras dapibus. Vivamus elementum semper nisi. Aenean vulputate eleifend tellus.</p>
<p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium quis, sem. Nulla consequat massa quis enim. Donec pede justo, fringilla vel, aliquet nec, vulputate eget, arcu. In enim justo, rhoncus ut, imperdiet a, venenatis vitae, justo. Nullam dictum felis eu pede mollis pretium. Integer tincidunt. Cras dapibus. Vivamus elementum semper nisi. Aenean vulputate eleifend tellus.</p>
</div>
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment