【功能实现】bilibili顶部鼠标跟随效果怎么实现?

我们在电脑端打开b站首页时,总会被顶部【鼠标跟随】的效果所吸引,那他是如何实现的,来研究一下。

b站效果:

分析:

1.监听鼠标的位置,当悬浮到该模块时,图片会随鼠标移动

2.引入图片的样式是动态的,会随鼠标移动而改变

实验:

1.准备好基本图片

背景也添加一个图片

javascript 复制代码
<div class="banner" >
        <img src="../assets/images/nav/castalia.png" alt="Background">
      <img  src="../assets/images/cat.png" alt="Background">
</div>
javascript 复制代码
.banner {
     margin: auto;
      width: 120%;
      height: 400px;
      border-radius: 8px;
      background: url(@/assets/images/backimage4.jpeg) no-repeat;
      background-size: cover;
    }

2.实现监听鼠标位置

引入三个方法,分别监听鼠标移动时的状态

javascript 复制代码
<div class="banner" 
 @mousemove="onMouseMove">

</div>

3.鼠标移动时改变样式

分别为背景和两张图片添加绑定样式

javascript 复制代码
<div class="banner" :style="textStyle" 
 @mousemove="onMouseMove" >
 <img :style="pngStyle1" src="../assets/images/nav/castalia.png" alt="Background">
 <img :style="textStyle" src="../assets/images/cat.png" alt="Background">
 
 </div>

设定样式初始值

javascript 复制代码
const startX = ref(0);
const currentX = ref(0);
const pngStyle = ref({
  transition: 'transform 0.3s',
  transform: 'translate(0px, 0px)',
});
const pngStyle1 = ref({
  transition: 'transform 0.2s',
  transform: 'translate(0px, 0px)',
});
const textStyle = ref({
  transition: 'transform 0.1s',
  transform: 'translate(0px, 0px)',
});

设定方法:

javascript 复制代码
 
const onMouseMove = (event) => {
   currentX.value = event.clientX;//鼠标事件发生时,鼠标指针相对于浏览器窗口的 X 坐标
  const disx = currentX.value - startX.value;//计算鼠标从开始位置到当前位置的水平距离。
  const move = disx / 18;//设定图片应该移动的距离
  const move1 = -disx / 18;
  const move2 = -disx / 14;
  pngStyle.value.transform = `translate(${move}px, 0px)`;
  pngStyle1.value.transform = `translate(${move}px, 0px)`;
  textStyle.value.transform = `translate(${move1}px, 0px)`;
};
 

这样一个基本效果就完成了,可以根据自己想要的效果增加图片,调解移动的距离,移动的方向等。

大家加油!!!

相关推荐
火车叼位4 分钟前
脚本伪装:让 Python 与 Node.js 像原生 Shell 命令一样运行
运维·javascript·python
VT.馒头4 分钟前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
鹏北海4 分钟前
micro-app 微前端项目部署指南
前端·nginx·微服务
发现一只大呆瓜7 分钟前
虚拟列表:从定高到动态高度的 Vue 3 & React 满分实现
前端·vue.js·react.js
css趣多多11 分钟前
add组件增删改的表单处理
java·服务器·前端
证榜样呀17 分钟前
2026 大专计算机专业必考证书推荐什么
大数据·前端
蓝帆傲亦24 分钟前
前端性能极速优化完全指南:从加载秒开体验到丝滑交互
前端·交互
鱼毓屿御36 分钟前
如何给用户添加权限
前端·javascript·vue.js
JustHappy40 分钟前
「web extensions🛠️」有关浏览器扩展,开发前你需要知道一些......
前端·javascript·开源
何中应1 小时前
nvm安装使用
前端·node.js·开发工具