七夏 发表于 2024-10-16 01:03:42

前端纯CSS特效丨打造酷炫微软风按钮特效

> 特效展示

![图片](https://www.3bbs.cn/index-diy/img.php?url=https://mmbiz.qpic.cn/sz_mmbiz_gif/dLtTnNkuaUytR5QugOSJKTkiaUQicBCI437e2U5Zibgm98iaEbxg3adC2PJmE7x8a5EGUa5h2fPjs0YLWiaq7kSNMIQ/640?wx_fmt=gif&from=appmsg&tp=webp&wxfrom=5&wx_lazy=1&wx_co=1)

**一、整体布局与基础样式**

1. 首先,通过设置 `.brutalist-button` 的样式,确定了按钮的整体外观。
   * `display: flex; align-items: center;` 使按钮内部的元素能够垂直居中对齐,确保布局的整齐性。
   * `width: 169px; height: 60px; background-color: #000; color: #fff;` 定义了按钮的宽度、高度、背景颜色和文字颜色,为按钮奠定了基础的视觉风格。
   * `font-family: Arial, sans-serif; font-weight: bold;` 设置了字体样式,使其更加醒目。
   * `border: 3px solid #fff; outline: 3px solid #000; box-shadow: 6px 6px 0 #00a4ef;` 分别定义了边框、轮廓和阴影效果,增强了按钮的立体感。
2. 对于微软标志部分 `.ms-logo`,使用 `display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px;` 创建了一个 2x2 的网格布局,四个小方块分别占据一个网格单元,实现了微软标志的基本形状。宽度和高度的设置以及 `flex-shrink: 0;` 确保标志在按钮中的尺寸固定且不会被压缩。
3. 按钮文字部分 `.button-text` 通过 `display: flex; flex-direction: column; line-height: 1.2;` 实现了垂直排列的文字布局,使上下两行文字能够清晰地展示在按钮上。

```
<body>
<button class="brutalist-button">
    <div class="ms-logo">
      <div class="ms-logo-square"></div>
      <div class="ms-logo-square"></div>
      <div class="ms-logo-square"></div>
      <div class="ms-logo-square"></div>
    </div>
    <div class="button-text">
      <span>Get it from</span>
      <span>Microsoft</span>
    </div>
</button>

</body>
```

**二、伪元素实现动态效果**

1. `.brutalist-button::before` 是实现按钮动态效果的关键之一。
   * 通过 `position: absolute; top: 0; left: -100%; width: 100%; height: 100%;` 将伪元素定位在按钮的上方,并初始状态下将其向左移出按钮范围。
   * `background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.8), transparent);` 设置了一个从左到右的线性渐变背景,初始时为透明,中间部分为半透明的白色,再到透明,为后续的动画效果提供了基础。
   * `z-index: 1; transition: none; opacity: 0;` 设置了伪元素的层级和初始不透明度为 0,使其在初始状态下不可见。
2. 当鼠标悬停在按钮上时,`.brutalist-button:hover::before` 的样式生效。

* `opacity: 1;` 使伪元素变为可见状态。
* `animation: slide 2s infinite;` 触发名为 `slide` 的动画,该动画在 2 秒内无限循环,实现了伪元素从左至右的滑动效果。动画定义在 `@keyframes slide` 中,通过 `0% { left: -100%; }` 和 `100% { left: 100%; }` 确定了伪元素在动画开始和结束时的位置。

**三、交互效果**

1. 鼠标悬停效果:
   * `.brutalist-button:hover` 定义了鼠标悬停在按钮上时的样式变化。
   * `transform: translate(-4px, -4px);` 使按钮向上和向左移动 4 像素,营造出一种立体的悬浮感。
   * `box-shadow: 10px 10px 0 #000;` 改变了阴影效果,使其更加深邃。
   * `.brutalist-button:hover.ms-logo` 使微软标志旋转 `-10deg` 并放大 `1.1` 倍,增加了动态效果。
   * `.brutalist-button:hover.button-text` 使按钮文字倾斜 `-5deg`,进一步增强了整体的交互感。
2. 鼠标点击效果:

* `.brutalist-button:active` 定义了按钮被点击时的样式。
* `transform: translate(4px, 4px);` 使按钮向下和向右移动 4 像素,给出明确的点击反馈。
* `box-shadow: 0px 0px 0 #00a4ef;` 去除了阴影效果。
* `background-color: #fff; color: #000; border-color: #000;` 反转了按钮的颜色,使其与点击前形成鲜明对比。
* `.brutalist-button:active.ms-logo` 使微软标志旋转 `10deg` 并缩小 `0.9` 倍。
* `.brutalist-button:active.button-text` 使按钮文字倾斜 `5deg`。

```
<style>
.brutalist-button {
    display: flex;
    align-items: center;
    cursor: pointer;
    width: 169px;
    height: 60px;
    background-color: #000;
    color: #fff;
    text-decoration: none;
    font-family: Arial, sans-serif;
    font-weight: bold;
    border: 3px solid #fff;
    outline: 3px solid #000;
    box-shadow: 6px 6px 0 #00a4ef;
    transition: all 0.1s ease-out;
    padding: 0 15px;
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
}

.brutalist-button::before {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg,
      transparent,
      rgba(255, 255, 255, 0.8),
      transparent);
    z-index: 1;
    transition: none;
    /* Initially hide the pseudo-element */
    opacity: 0;
}

@keyframes slide {
    0% {
      left: -100%;
    }

    100% {
      left: 100%;
    }
}

.brutalist-button:hover::before {
    /* Show the pseudo-element on hover */
    opacity: 1;
    animation: slide 2s infinite;
}

.brutalist-button:hover {
    transform: translate(-4px, -4px);
    box-shadow: 10px 10px 0 #000;
    background-color: #000;
    color: #fff;
}

@keyframes slide {
    0% {
      left: -100%;
    }

    100% {
      left: 100%;
    }
}

.brutalist-button:active {
    transform: translate(4px, 4px);
    box-shadow: 0px 0px 0 #00a4ef;
    background-color: #fff;
    color: #000;
    border-color: #000;
}

/* Rest of the CSS remains the same */

.ms-logo {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1px;
    width: 26px;
    height: 26px;
    margin-right: 8px;
    flex-shrink: 0;
    transition: transform 0.2s ease-out;
    position: relative;
    z-index: 1;
}

.brutalist-button:hover .ms-logo {
    transform: rotate(-10deg) scale(1.1);
}

.brutalist-button:active .ms-logo {
    transform: rotate(10deg) scale(0.9);
}

.ms-logo-square {
    width: 100%;
    height: 100%;
}

.ms-logo-square:nth-child(1) {
    background-color: #f25022;
}

.ms-logo-square:nth-child(2) {
    background-color: #7fba00;
}

.ms-logo-square:nth-child(3) {
    background-color: #00a4ef;
}

.ms-logo-square:nth-child(4) {
    background-color: #ffb900;
}

.button-text {
    display: flex;
    flex-direction: column;
    line-height: 1.2;
    transition: transform 0.2s ease-out;
    position: relative;
    z-index: 1;
}

.brutalist-button:hover .button-text {
    transform: skew(-5deg);
}

.brutalist-button:active .button-text {
    transform: skew(5deg);
}

.button-text span:first-child {
    font-size: 11px;
    text-transform: uppercase;
}

.button-text span:last-child {
    font-size: 16px;
    text-transform: uppercase;
}
</style>
```
页: [1]
查看完整版本: 前端纯CSS特效丨打造酷炫微软风按钮特效