一款很有创意的CSS3 3D倾斜视差图片展示动画特效,鼠标移动到页面不同位置查看视差动画效果。
js代码
<script>
js代码
<script>
var cards = document.querySelector(".cards");
var images = document.querySelectorAll(".card__img");
var backgrounds = document.querySelectorAll(".card__bg");
var range = 40;
// const calcValue = (a, b) => (((a * 100) / b) * (range / 100) -(range / 2)).toFixed(1);
var calcValue = function calcValue(a, b) {return (a / b * range - range / 2).toFixed(1);}; // thanks @alice-mx
var timeout = void 0;
document.addEventListener('mousemove', function (_ref) {var x = _ref.x,y = _ref.y;
if (timeout) {
window.cancelAnimationFrame(timeout);
}
timeout = window.requestAnimationFrame(function () {
var yValue = calcValue(y, window.innerHeight);
var xValue = calcValue(x, window.innerWidth);
console.log(xValue, yValue);
cards.style.transform = "rotateX(" + yValue + "deg) rotateY(" + xValue + "deg)";
[].forEach.call(images, function (image) {
image.style.transform = "translateX(" + -xValue + "px) translateY(" + yValue + "px)";
});
[].forEach.call(backgrounds, function (background) {
background.style.backgroundPosition = xValue * .45 + "px " + -yValue * .45 + "px";
});
});
}, false);
</script>