https://stackblitz.com/edit/web-platfor ... ile=script. js
Код: Выделить всё
const container = document.querySelector('.container');
const map = document.querySelector('.map');
const scaleStep = 0.2;
let scale = 1;
container.addEventListener('wheel', (event) => {
event.preventDefault();
if (!event.ctrlKey) {
return;
}
event.deltaY < 0 ? (scale += scaleStep) : (scale -= scaleStep);
const originX = container.scrollLeft + event.clientX;
const originY = container.scrollTop + event.clientY;
map.style.transformOrigin = `${originX}px ${originY}px`;
map.style.transform = `scale(${scale})`;
});
Код: Выделить всё
body * {
box-sizing: border-box;
}
.container {
width: 90vw;
height: 90vh;
border: 2px solid blue;
padding: 10px;
}
.map {
width: 100%;
height: 100%;
border: 2px solid aqua;
}
#node-1 {
position: absolute;
left: 50px;
top: 50px;
}
#node-2 {
position: absolute;
left: 150px;
top: 150px;
}
#node-3 {
position: absolute;
left: 250px;
top: 250px;
}
Код: Выделить всё
node-1
node-2
node-3
Моя цель — избавиться от этого «прыжка» курсора.
Моя цель — избавиться от этого «прыжка» курсора.
Моя цель — избавиться от этого «прыжка» курсора.
Моя цель — избавиться от этого «прыжка» курсора.
Моя цель — избавиться от этого «прыжка» курсора.
Моя цель — избавиться от этого «прыжка» курсора.
Моя цель — избавиться от этого «прыжка» курсора. п>
Подробнее здесь: https://stackoverflow.com/questions/772 ... rsor-point