在简书里面,每一篇文章底部都有喜欢这个按钮,如同上图的这个效果,体验很是好,到底是怎么作的呢?
首先,做为前端攻城狮的咱们,来右键查看一波↓
看到这个其实是一个伪类,而后放的背景图片,咱们把这个背景图片在新标签页中打开,会看到这样一个图片,有点像之前作的那种雪碧图css
而后,咱们把这张图片下载下来到本地,新建个HTML,先把button的基本样式写出来html
<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>
获得基本的按钮样式了前端
而后咱们再写动画的样式
首先,咱们要数一下这个动画总共有多少步,就是去数 喜欢的背景图总共有多少幅,再去减一。数出来总共19步,先存着,后面会用到。
而后,咱们打算用伪类来实现这个动画,
先写基本的css3
.like::before{ content: ''; position: absolute; left: 5px; top: 2px; width: 50px; height: 50px; }
而后咱们把那个背景图引入进去web
.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; }
这样咱们就获得了"喜欢"的最终完成的时候的样式了less
可是咱们须要像 简书 那样,点击的时候会出现一个动画,这个动画怎么实现的,相关技术传送门
添加如下代码动画
@keyframes like{ 0%{background-position: left;}; 100%{background-position: right;} }
这个就是定义一个动画,开始的时候是最左边,结束就是最右边,还要在like的样式里加多一句url
animation:like 0.6s 1 steps(19);
这样一刷新就能看到咱们的动画了,为了追求完美,即点击的时候出现动画,再点一下又没有,再点一下又出来,咱们须要添加一个点击事件。spa
<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>
这样,一个最简单的 简书喜欢动画就完成了。3d