前端 CSS 经典:SVG 描边动画

1. 原理

使用 css 中的 stroke 属性,用来描述描边的样式,其中重要的属性 stroke-dasharraystroke-dashoffset。理解了这两个属性的原理,才能理解描边动画实现的原理。

stroke-dasharray:将描边线变成虚线、其中实线和虚线部分的长度就是它的值。

stroke-dashoffset:描边线的偏移量。为正数时往左偏移。

实现原理:将 stroke-dasharray 和 stroke-dashoffset 设置为

svg 中 path 的长度,这样初始状态就是无边状态,其中 path 长度需要动态获取,通过 getTotalLength 方法可以获取 path 的长度。设置动画,将描边线的偏移量 stroke-dashoffset 设为 0,这样 svg 就从无边状态变成有边状态,其中变化的过程就是描边动画。

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      .p {
        /* 如果 svg 为封闭图,那么默认填充为黑色,需要将填充色去掉,设置为 none */
        fill: none;
        /* 描边线颜色 */
        stroke: #f40;
        /* 描边线宽度 */
        stroke-width: 10;
        /* 描边线头设为圆头 */
        stroke-linecap: round;
        /* --l 为变量,通过 js 动态获取 */
        stroke-dasharray: var(--l);
        stroke-dashoffset: var(--l);
        /* forwards当动画完成后,保持最后一帧的状态 */
        animation: stroke 2s forwards;
      }
      @keyframes stroke {
        to {
          stroke-dashoffset: 0;
        }
      }
    </style>
  </head>
  <body>
    <svg class="icon" viewBox="0 0 1024 1024" width="200" height="200">
      <path
        class="p"
        d="M512 0a512 512 0 1 0 512 512A512 512 0 0 0 512 0zM213.333 832A298.667 298.667 0 0 1 512 533.333a170.667 170.667 0 1 1 170.667-170.666A170.667 170.667 0 0 1 512 533.333 298.667 298.667 0 0 1 810.667 832z"
      ></path>
    </svg>
  </body>
  <script>
    // 拿到 svg 路径
    const paths = document.querySelectorAll(".icon .p");
    // 遍历路径,动态获取路径长度,然后复制。
    paths.forEach((path) => {
      // getTotalLength 能拿到当前 path 路径的长度
      const len = path.getTotalLength() + 1;
      path.style.setProperty("--l", len);
    });
  </script>
</html>

相关推荐

  1. CSS】实现文字

    2024-05-25 20:00:58       17 阅读
  2. 前端 CSS 经典CSS 原子化

    2024-05-25 20:00:58       8 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-05-25 20:00:58       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-25 20:00:58       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-25 20:00:58       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-25 20:00:58       20 阅读

热门阅读

  1. uniapp 微信小程序设置 TabItem 红点

    2024-05-25 20:00:58       12 阅读
  2. Netty:AIO

    2024-05-25 20:00:58       12 阅读
  3. 前端常用的状态码

    2024-05-25 20:00:58       10 阅读
  4. 测试驱动开发(TDD)的探析

    2024-05-25 20:00:58       11 阅读
  5. vue的图片上传

    2024-05-25 20:00:58       8 阅读
  6. 【设计模式】单例模式的任务队列

    2024-05-25 20:00:58       10 阅读
  7. Python学习---基于TCP的模拟浏览器请求响应案例

    2024-05-25 20:00:58       11 阅读
  8. 【Python】单例模式和工厂模式

    2024-05-25 20:00:58       9 阅读
  9. 如何选择适合自己需求的扬州独立服务器方案?

    2024-05-25 20:00:58       10 阅读
  10. 什么是分布式?为什么需要分布式?

    2024-05-25 20:00:58       9 阅读
  11. 07网络编程及网络基础知识

    2024-05-25 20:00:58       9 阅读
  12. 货币系统一(DP[i][j]二维)

    2024-05-25 20:00:58       11 阅读