Mouse Parallax 鼠标视差跟随,视觉差

网页中鼠标移动,元素或背景图片轻微移动特效

这种效果通常称为 Mouse Parallax(鼠标视差跟随),常用于 Banner、产品展示页、高端企业官网。

方案1:背景图片轻微移动(推荐)

HTML:

复制代码
复制代码
<div class="banner">
    <img src="banner.jpg" alt="">
</div>

CSS:

复制代码
复制代码
.banner{
    width:100%;
    height:600px;
    overflow:hidden;
    position:relative;
}

.banner img{
    width:110%;
    height:110%;
    object-fit:cover;
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%,-50%);
    transition:transform .15s ease-out;
}

JS:

复制代码
复制代码
const banner = document.querySelector('.banner');
const img = banner.querySelector('img');

banner.addEventListener('mousemove', function(e){

    const x = (e.clientX / window.innerWidth - 0.5) * 20;
    const y = (e.clientY / window.innerHeight - 0.5) * 20;

    img.style.transform =
        `translate(calc(-50% + ${x}px), calc(-50% + ${y}px))`;

});

效果:

  • 鼠标向右 → 图片轻微向右
  • 鼠标向左 → 图片轻微向左
  • 最大移动约 20px
  • 非常适合 Banner

方案2:元素跟随鼠标

HTML:

复制代码
复制代码
<div class="banner">
    <div class="floating"></div>
</div>

CSS:

复制代码
复制代码
.banner{
    height:600px;
    position:relative;
}

.floating{
    width:300px;
    height:300px;
    background:#0a84ff;
    border-radius:20px;

    position:absolute;
    left:50%;
    top:50%;

    transform:translate(-50%,-50%);
    transition:transform .2s ease-out;
}

JS:

复制代码
复制代码
const floating = document.querySelector('.floating');

document.addEventListener('mousemove', function(e){

    const x = (e.clientX - window.innerWidth/2) / 40;
    const y = (e.clientY - window.innerHeight/2) / 40;

    floating.style.transform =
        `translate(calc(-50% + ${x}px), calc(-50% + ${y}px))`;

});

方案3:多层视差(高级官网常用)

HTML:

复制代码
复制代码
<div class="banner">
    <img class="layer layer1" src="bg.png">
    <img class="layer layer2" src="machine.png">
    <img class="layer layer3" src="bottle.png">
</div>

JS:

复制代码
复制代码
const layers = document.querySelectorAll('.layer');

document.addEventListener('mousemove', e => {

    let x = e.clientX / window.innerWidth - 0.5;
    let y = e.clientY / window.innerHeight - 0.5;

    layers.forEach((layer,index)=>{

        let speed = (index + 1) * 10;

        layer.style.transform =
            `translate(${x * speed}px, ${y * speed}px)`;

    });

});

效果:

  • 背景层移动最慢
  • 产品层移动中等
  • 前景装饰层移动最快

类似:

4


方案4:性能最佳(推荐用于企业官网)

使用 requestAnimationFrame,动画更丝滑:

复制代码
复制代码
const banner = document.querySelector('.banner');

let mouseX = 0;
let mouseY = 0;

let currentX = 0;
let currentY = 0;

banner.addEventListener('mousemove', e => {

    mouseX = (e.clientX - window.innerWidth/2) * 0.02;
    mouseY = (e.clientY - window.innerHeight/2) * 0.02;

});

function animate(){

    currentX += (mouseX - currentX) * 0.08;
    currentY += (mouseY - currentY) * 0.08;

    banner.style.transform =
        `translate(${currentX}px, ${currentY}px)`;

    requestAnimationFrame(animate);

}

animate();

优点:

  • 不会频繁触发重排
  • CPU占用低
  • mousemove + transition 更流畅

形成轻微 3D 视差效果,既高级又不会影响性能。

相关推荐
集芯微电科技有限公司16 天前
四通道2A输出集成功率电感降压模块专为紧凑型方案设计
人工智能·单片机·嵌入式硬件·生成对抗网络·计算机外设
lichong95116 天前
让AI自己用电脑!Cua:后台操作鼠标键盘,Mac/Windows/Linux全支持
人工智能·macos·ai·计算机外设·agent·提示词
Saniffer_SH17 天前
【高清视频】Gen6 服务器还没到,Gen6 SSD 怎么测?Emily 现场演示三种测试环境
人工智能·驱动开发·测试工具·缓存·fpga开发·计算机外设·压力测试
阿泽·黑核17 天前
05 keyflow 扩展设计方案:矩阵键盘/组合键/事件队列/中断驱动
线性代数·矩阵·计算机外设·嵌入式·agent·vibe coding
科技每日热闻17 天前
618 AI显示器选购指南!爱攻AGON AI定制芯片电竞显示器AG277UX,适合哪些玩家?
人工智能·科技·游戏·计算机外设
科技每日热闻17 天前
舒视蓝4.0 AI版!EVNIA弈威海王星系列护眼电竞显示器27M4P5501U来袭
人工智能·科技·游戏·计算机外设
开开心心_Every18 天前
界面干净的开源免费电视浏览器
人工智能·科技·智能手机·计算机外设·rabbitmq·语音识别·etcd
智塑未来20 天前
2026高性价比商用护眼显示器调研:飞利浦护眼技术与售后体系深度解析
计算机外设
移远通信20 天前
显示器-调试
单片机·嵌入式硬件·计算机外设
Legendary_00820 天前
LDR6020P:iPad 一体式皮套键盘 OTG 应用的核心引擎
ios·计算机外设·ipad