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

喜欢.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>

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

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    阳明AI阅读 16,211评论 3 119
  • 今天是离职交接的第一天。 在过去的几个星期里,我经历了5轮电话/视频面试和2轮现场面试,最终在昨天晚上完成了和组长...
    Tomtoms阅读 341评论 1 0
  • 一 雾浓星稀,南方小城高仿CBD区。王友根站在窗边往外看,哈气,...
    令狐二阅读 134评论 0 0

友情链接更多精彩内容