整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

html的css3实现带渐变的炫酷按钮

tml的css3实现带渐变的炫酷按钮

用到的技术有CSS3的渐变,CSS3动画等

效果图:

实现代码

html:

css:

何使用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:

次来看一个带特殊圆角导航栏布局,如下谷歌浏览器的标签栏:

这样一个布局如何实现呢?

CSS 渐变几乎是无所不能的,什么的图形都能绘制,这里可以拆分一下,两个矩形,两个圆形,还有两个反向圆角,也就是 2 个 线性渐变,4 个径向渐变,示意如下:

最终实时效果如下(上面是原理图)

完整代码如下:


上一篇:HTML入门
下一篇:HTML URL编码