data:image/s3,"s3://crabby-images/83681/83681c25e200d46b498abe78781bec136761f83c" alt="".webp)
Horizontal Click & Drag
Tutorial
Learn how to create a click-and-drag horizontal, CMS-powered slider in Webflow. Watch the Youtube tutorial and clone the Webflow project to follow along.
Horizontal Click & Drag
<script>
document.addEventListener('DOMContentLoaded', function() {
const ele = document.getElementById('clickanddrag');
// Check if the screen width is greater than 768px (adjust this value as needed)
if (window.innerWidth > 768) {
ele.style.cursor = 'grab';
let pos = { top: 0, left: 0, x: 0, y: 0 };
ele.style.overflowX = 'hidden'; // Hide the horizontal scrollbar
const mouseDownHandler = function(e) {
ele.style.cursor = 'grabbing';
ele.style.userSelect = 'none';
pos = {
left: ele.scrollLeft,
top: ele.scrollTop,
x: e.clientX,
y: e.clientY,
};
document.addEventListener('mousemove', mouseMoveHandler);
document.addEventListener('mouseup', mouseUpHandler);
};
const mouseMoveHandler = function(e) {
const dx = e.clientX - pos.x;
const dy = e.clientY - pos.y;
ele.scrollTop = pos.top - dy;
ele.scrollLeft = pos.left - dx;
};
const mouseUpHandler = function() {
ele.style.cursor = 'grab';
ele.style.removeProperty('user-select');
document.removeEventListener('mousemove', mouseMoveHandler);
document.removeEventListener('mouseup', mouseUpHandler);
};
ele.addEventListener('mousedown', mouseDownHandler);
}
});
</script>
view more
data:image/s3,"s3://crabby-images/6130d/6130dafebf22d728cfe82bcbc52c1a5357048718" alt=""
Learn how to use a CSS clip-path and GSAP to create an unmasking scrolling transition.
data:image/s3,"s3://crabby-images/f60c1/f60c1e3aba1120508a759d166620518d190d3b08" alt=""
Learn the art of creating global components, allowing you to effortlessly reuse video elements that perfectly fit and cover their containers. Harness the power of Webflow's custom elements.
data:image/s3,"s3://crabby-images/e74eb/e74eb45a1a466450405deffcc5639edd1127c2f6" alt=""
Learn the art of creating global components, allowing you to effortlessly reuse video elements that perfectly fit and cover their containers. Harness the power of Webflow's custom elements.