计算机系统应用教程网站

网站首页 > 技术文章 正文

css 渐变跟随鼠标光标按钮动画

btikc 2024-09-06 18:13:55 技术文章 17 ℃ 0 评论

如何使用css实现渐变跟随鼠标光标的悬停效果。如下图:

实现思路:

  1. 声明 --x 和- -y 两个 CSS 变量,用于跟踪鼠标在按钮上的位置。
  2. 声明一个 --size 的 CSS 变量,用于修改背景渐变的尺寸大小。
  3. 使用 background: radial-gradient(circle closest-side, pink, transparent) 创建按钮的径向渐变背景效果。
  4. 使用document.querySelector()和EventTarget.addEventListener()给按钮绑定'mousemove'事件。
  5. 使用element.getBoundingClientRect()和CSSStyleDeclaration.setProperty() 更新 --x 和--y 变量的值。

html:

<button class="mouse-cursor-gradient-tracking">
  <span>Hover me</span>
</button>

css:

/*按钮基本样式*/
.mouse-cursor-gradient-tracking {
  position: relative;
  background: #7983ff;
  padding: 0.5rem 1rem;
  font-size: 1.2rem;
  border: none;
  color: white;
  cursor: pointer;
  outline: none;
  overflow: hidden;
}
.mouse-cursor-gradient-tracking span {
  position: relative;
}
/*按钮渐变背景,这里使用伪类实现,并且使用transform动画*/
.mouse-cursor-gradient-tracking:before {
  --size: 0; /*渐变背景尺寸*/
  content: '';
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: var(--size);
  height: var(--size);
  /*背景渐变*/
  background: radial-gradient(circle closest-side, pink, transparent);
  /*动画效果*/
  transform: translate(-50%, -50%); 
  transition: width 0.2s ease, height 0.2s ease;
}
/*鼠标经过按钮时*/
.mouse-cursor-gradient-tracking:hover:before {
  --size: 200px;
}

javascript:

// 获取按钮元素
let btn = document.querySelector('.mouse-cursor-gradient-tracking');
// 绑定鼠标移动事件
btn.addEventListener('mousemove', e => {
  // 获取按钮的左,上,右和下分别相对浏览器视窗的位置
  let rect = e.target.getBoundingClientRect();
  // 计算鼠标坐标相对于按钮左、上的距离
  let x = e.clientX - rect.left;
  let y = e.clientY - rect.top;
  // 更新背景渐变区域的坐标
  btn.style.setProperty('--x', x + 'px');
  btn.style.setProperty('--y', y + 'px');
});

Tags:

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表