当前位置: 首页 > article >正文

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

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

b站效果:

分析:

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

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

实验:

1.准备好基本图片

背景也添加一个图片

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

2.实现监听鼠标位置

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

<div class="banner" 
 @mousemove="onMouseMove">

</div>

3.鼠标移动时改变样式

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

<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>

设定样式初始值

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)',
});

设定方法:


 
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)`;
};
 

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

大家加油!!!


http://www.kler.cn/a/406639.html

相关文章:

  • IDEA 2024.3 版本更新主要功能介绍
  • 【数据结构】归并排序 —— 递归及非递归解决归并排序
  • 基于RTEMS项目学习waf build system
  • 当产业经济插上“数字羽翼”,魔珐有言AIGC“3D视频创作大赛”成功举办
  • 渗透测试---shell(5)字符串运算符与逻辑运算符
  • 远程管理不再难!树莓派5安装Raspberry Pi OS并实现使用VNC异地连接
  • Python +Pyqt5 简单视频爬取学习及工具实现(二)
  • 5.STM32之通信接口《精讲》之USART通信---实验串口接收程序
  • 关于汽车多核架构
  • 算法专题十一: 基础递归
  • Tomcat 任意写入文件漏洞(CVE-2017-12615)
  • docker镜像源配置、换源、dockerhub国内镜像最新可用加速源(仓库)
  • 10 分钟,教你如何用 LLama-Factory 训练和微调 LLama3 模型
  • 计算机网络(14)ip地址超详解
  • Vision-Language Models for Vision Tasks: A Survey 论文解读
  • 【代码随想录day36】【C++复健】1049. 最后一块石头的重量 II ; 494. 目标和 ;474.一和零
  • MIT 6.S081 | 操作系统 | Lab1: Xv6 and Unix utilities
  • SSRF漏洞利用
  • Unity——使用Unity制作BIM全景视频、图片
  • C#语言入门
  • 02 DHCP搭建
  • 服务器被隔离导致无法登录
  • 运维之网络安全抓包—— WireShark 和 tcpdump
  • 在SpringBoot项目中集成MongoDB
  • 测评部署和管理 WordPress 最方便的面板
  • Sqlsugar Oracle 配置 和服务注册以及使用