svg描边动画的实现

svg描边的动画效果,主要由stroke-dasharray和stroke-dashoffset两个属性实现.

svg的路径动画绘制步骤:

(1) 用getTotalLength()方法获取path的路径总长度

let logo = document.querySelectorAll('.text-box')
    // getTotalLength()反回用户代理对路径总长度
    console.log(path.getTotalLength())

(2)设置stroke每段虚线的间距和偏移量为总长度

(3)使用动画将偏移量设置为初始值0
stroke-dasharray:每段虚线的偏移距离
stroke-dashoffset:偏移量

如果直接是文字构成,不是通过path绘制,可将stroke-dasharray和stroke-dashoffset设置成100%.

  <svg id="text-box" width="1000px" height="200px" fill="none">
        <text class="svgText" x="100" y="100">WELCOME</text>
  </svg>
        #text-box {
            background-color: #ccc;
        }

        text {
            font-size: 70px;
            font-weight: 900;
            stroke-width: 2px;
            stroke:chocolate;
            fill:transparent;
            letter-spacing: 6px;
            stroke-dasharray: 100%;
            stroke-dashoffset: 100%;
            animation: svgStroke 3s ease forwards;
        }

        @keyframes svgStroke {
            90% {
                stroke-dashoffset: 0;
            }
            100% {
                stroke-dashoffset: 0;
                fill:chocolate;
            }
        }

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值