Twitter点赞红心按钮CSS3动画特效

这是一款效果非常炫酷的仿 Twitter“点赞”红心按钮 CSS3 动画特效。该“点赞”特效使用一颗心形按钮,在用户点击心形按钮的时候,心形按钮由灰色变为红色,同时会在心形按钮的四周产生类似烟花爆炸的效果。

HTML 结构

该“点赞”红心按钮的 HTML 结构是将心形按钮放在一个超链接的后面或下面,它的 HTML 结果如下:

<div class="feed" id="feed1"><p>jQuery之家 <a href="http://www.htmleaf.com/">http://www.htmleaf.com/a>p><div class="heart" id="like3" rel="like">div><div class="likeCount" id="likeCount3">24div>
div>

CSS 样式

整个“点赞”烟花爆炸效果实际上是使用背景图片的连续播放来完成的,它使用一张很长的雪碧(Sprite)图片,然后在点击红心按钮是逐帧进行播放。下面是开始时显示第一帧的 CSS 样式:

.heart {
  background: url(images/web_heart_animation.png);
  background-position: left;
  background-repeat: no-repeat;
  height: 50px;
  width: 50px;
  cursor: pointer;
  position: absolute;
  left:-14px;
  background-size:1450px; //实际背景图片尺寸2900px
}
.heart:hover{
  background-position: right; //显示最后一个红心帧
}
.likeCount{
  margin-top: 13px;
  margin-left: 28px;
  font-size: 16px;
  color: #999999
}

下面的代码是逐帧播放红心背景图片,它使用 CSS3 keyframe 帧动画来完成。

@-webkit-keyframes heartBlast {
  0% {background-position: left;}
  100% {background-position: right;}
}
 
@keyframes heartBlast {
  0% {background-position: left;}
  100% {background-position: right;}
}
 
.heartAnimation {
  -webkit-animation-name: heartBlast; //webkit内核浏览器
  animation-name: heartBlast;
  -webkit-animation-duration: .8s;
  animation-duration: .8s;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
  -webkit-animation-timing-function: steps(28); //共28个背景图片帧
  animation-timing-function: steps(28);
  background-position: right;
}

JavaScript

在这个“点赞”红心动画特效中使用 jQuery 代码来使红心按钮在点击时与相应的总点赞数量进行联动。你可以通过 ajax 来进行数据库操作。当用户点赞时,总数量加 1,取消点赞时,总数量减 1。

<script>
$(document).ready(function(){
  $('body').on("click",'.heart',function(){
    var A=$(this).attr("id");
    var B=A.split("like"); //splitting like1 to 1var messageID=B[1];
    $(this).css("background-position","")
    var D=$(this).attr("rel");
 
    $.ajax({
      type: "POST",
      url: "message_like_ajax.php",
      data: dataString,
      cache: false,
      success: function(data){
      $("#likeCount"+messageID).html(data);
      if(D === 'like') {
        $(this).addClass("heartAnimation").attr("rel","unlike"); //applying animation class
      }
      else{
        $(this).removeClass("heartAnimation").attr("rel","like");
        $(this).css("background-position","left");
      }
    }); //ajax end
 
  });//heart click end
 
});
script>

人已赞赏
技术分享技术文档

教你如何在linux终端上测试网速

2019-10-11 13:15:54

WP美化技术文档

wordpress 知更鸟主题登录页面美化,WordPress后台的登录页面美化

2019-10-13 20:20:05

⚠️
91lxs.com上的部份代码及教程来源于互联网,仅供网友学习交流,未经念于惜作者或上传书面授权,请勿作他用。
若您的权利被侵害,请联系站长 QQ: 482314363 或 点击右侧 私信:念于惜 反馈,我们将尽快处理。
0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索