使用CSS变量和JavaScript实现鼠标跟随渐变

实现鼠标跟随渐变效果的详细过程:

1. HTML 结构

我们在 HTML 中创建了一个 <div> 元素,用于展示渐变效果。这个元素的 ID 是 gradient-box,方便在 JavaScript 中进行操作。

2. CSS 样式

  • CSS 变量 :在 :root 中定义了两个 CSS 变量 --mouse-x--mouse-y,用于存储鼠标位置的百分比值。这些变量会被用于控制渐变的中心位置。
  • 渐变背景div 元素的背景设置为径向渐变(radial-gradient),其中心位置由 --mouse-x--mouse-y 控制。初始值为 50%,即居中显示。

3. JavaScript 逻辑

  • 事件监听 :为 div 元素添加 mousemove 事件监听器。当鼠标在 div 上移动时,会触发 updateMousePosition 函数。
  • 计算鼠标位置
    • 使用 getBoundingClientRect() 获取 div 元素的边界信息。
    • 计算鼠标在 div 内的相对位置,并将其转换为百分比值。
  • 更新 CSS 变量
    • 使用 style.setProperty() 方法,将计算得到的百分比值更新到 --mouse-x--mouse-y 变量上。
    • 由于这些变量直接影响 div 的背景渐变,因此每次鼠标移动时,渐变的中心位置都会实时更新。

4. 整体效果

通过上述步骤,div 元素的背景渐变会根据鼠标在其上的位置动态变化,形成一个跟随鼠标移动的视觉效果。这种实现方式利用了 CSS 变量的动态特性和 JavaScript 的事件处理能力,使得效果流畅且易于维护。

代码如下

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        :root {
            --mouse-x: 50%;
            --mouse-y: 50%;
        }
        div {
            width: 1200px;
            height: 1200px;
            cursor: pointer;
            border: 1px solid #6794ee;
            background: radial-gradient(circle at var(--mouse-x) var(--mouse-y),
            rgba(10, 34, 243, 0.5),
            rgba(255, 0, 0, 0.2));
        }
    </style>
</head>
<body>
    <div id="gradient-box">
    </div>

    <script>
        // 修正函数定义
        function updateMousePosition(event) {
            const rect = event.currentTarget.getBoundingClientRect();
            const mouseX = ((event.clientX - rect.left) / rect.width) * 100;
            const mouseY = ((event.clientY - rect.top) / rect.height) * 100;
            document.documentElement.style.setProperty('--mouse-x', `${mouseX}%`);
            document.documentElement.style.setProperty('--mouse-y', `${mouseY}%`);
        }

        // 添加事件监听
        const gradientBox = document.getElementById('gradient-box');
        gradientBox.addEventListener('mousemove', updateMousePosition);
    </script>
</body>
</html>
相关推荐
biyezuopinvip33 分钟前
基于Spring Boot的投资理财系统设计与实现(毕业论文)
java·spring boot·vue·毕业设计·论文·毕业论文·投资理财系统设计与实现
滕青山42 分钟前
URL编码/解码 核心JS实现
前端·javascript·vue.js
有马贵将1 小时前
【3】前端手撕-深浅拷贝
javascript
biyezuopinvip2 小时前
基于Spring Boot的投资理财系统设计与实现(任务书)
java·spring boot·vue·毕业设计·论文·任务书·投资理财系统设计与实现
柳杉3 小时前
使用AI从零打造炫酷的智慧城市大屏(开源):React + Recharts 实战分享
前端·javascript·数据可视化
Highcharts.js3 小时前
玩转Highcharts气泡图|从散点图到气泡图:增加一个维度,数据可视化瞬间立体起来
javascript·信息可视化·散点图·highcharts·图表开发·气泡图·图表创建
颜酱4 小时前
差分数组:高效处理数组区间批量更新的核心技巧
javascript·后端·算法
Joker Zxc4 小时前
【前端基础(Javascript部分)】2、JavaScript的变量和数据类型
开发语言·前端·javascript
颜酱6 小时前
前缀和技巧全解析:从基础到进阶
javascript·后端·算法
NEXT066 小时前
BFC布局
前端·css·面试