丑源

【网页代码】Twitter点赞红心按钮CSS3动画特效
这是一款效果非常炫酷的仿 Twitter“点赞”红心按钮 CSS3 动画特效。该“点赞”特效使用一颗心形按钮,在用...
扫描右侧二维码阅读全文
12
2019/10

【网页代码】Twitter点赞红心按钮CSS3动画特效

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

  1. 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>
  1. 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>

版权声明:本文为《念于惜》原创。
原文链接:https://www.91lxs.com/899.html

最后修改:2019 年 10 月 13 日 12 : 04 AM
如果觉得我的文章对你有用,请随意赞赏!

发表评论