美文网首页
CSS3动画实例——简书“喜欢”动画

CSS3动画实例——简书“喜欢”动画

作者: 红豆稀饭_a071 | 来源:发表于2018-07-30 14:24 被阅读0次
    喜欢.gif

    在简书里面,每一篇文章底部都有喜欢这个按钮,如同上图的这个效果,体验非常好,究竟是怎么做的呢?
    首先,作为前端攻城狮的我们,来右键查看一波↓


    右键

    看到这个实际上是一个伪类,然后放的背景图片,我们把这个背景图片在新标签页中打开,会看到这样一个图片,有点像以前做的那种雪碧图


    喜欢的背景图
    然后,我们把这张图片下载下来到本地,新建个HTML,先把button的基本样式写出来
    <style>
        #like{
            background: #EA6F5A;
            color: white;
            padding: 13px 0 15px 0;
            font-size: 19px;
            border: 1px solid #EA6F5A;
            border-radius: 40px;
            width: 100px;
            position: relative;
            padding-left: 20px;
            cursor: pointer;
            text-align: center;
        }
    </style>
    <div class="like"  onclick="like()" id="like">喜欢</div>
    

    得到基本的按钮样式了


    image.png

    然后我们再写动画的样式
    首先,我们要数一下这个动画总共有多少步,就是去数 喜欢的背景图总共有多少幅,再去减一。数出来总共19步,先存着,后面会用到。
    然后,我们打算用伪类来实现这个动画,
    先写基本的

    .like::before{
            content: '';
            position: absolute;
            left: 5px;
            top: 2px;
            width: 50px;
            height: 50px;
    }
    

    然后我们把那个背景图引入进去

    .like::before{
            content: '';
            position: absolute;
            left: 5px;
            top: 2px;
            width: 50px;
            height: 50px;
            background-image: url(https://cdn2.jianshu.io/assets/web/like_animation_steps-62a00a7b52377d3069927cdb8e61fd34.png);
            background-position: left;
            background-repeat: no-repeat;
            background-size: 1000px 50px;
            background-position: right;
    }
    

    这样我们就得到了"喜欢"的最终完成的时候的样式了

    动画最终完成的样式
    但是我们需要像 简书 那样,点击的时候会出现一个动画,这个动画怎么实现的,相关技术传送门
    添加以下代码
        @keyframes like{
            0%{background-position: left;};
            100%{background-position: right;}
        }
    

    这个就是定义一个动画,开始的时候是最左边,结束就是最右边,还要在like的样式里加多一句

    animation:like  0.6s 1 steps(19);
    

    这样一刷新就能看到我们的动画了,为了追求完美,即点击的时候出现动画,再点一下又没有,再点一下又出来,我们需要添加一个点击事件。

        <div class="like"  onclick="like()" id="like">喜欢</div>
        <script>
            function like(){
                var like = document.querySelector('#like');
                console.log(like.classList)
                if(like.classList.length == 0)
                    like.className = 'like'
                else
                    like.className = ''
            }
        </script>
    

    这样,一个最简单的 简书喜欢动画就完成了,喜欢的话,请点击下方喜欢哦(这样就可以再次欣赏这个美妙的动画了😆)

    相关文章

      网友评论

          本文标题:CSS3动画实例——简书“喜欢”动画

          本文链接:https://www.haomeiwen.com/subject/meaxvftx.html