点击页面计算点击次数特效

在我的博友无主题那里看到的一个特效,就是点击网页,会出现一个计算页面点击次数的特效,感觉挺有意思,跑去看看他的代码写法,然后我发现代码的效率还有改进的地方,于是我就手动修改了一番,一起来看看我的代码是怎么写的。

原来代码

<script>
var _click_count=0;
$("body").bind("click",function(e){ //直接给body一个事件好了. 
 //var n=Math.round(Math.random()*100);//随机数
 var $i=$("<b>").text("+"+(++_click_count));//添加到页面的元素
 var x=e.pageX,y=e.pageY;//鼠标点击的位置
 $i.css({
 "z-index":99999,
 "top":y-15,
 "left":x,
 "position":"absolute",
 "color":"red"
 });
 $("body").append($i);
 $i.animate(
 {"top":y-180,"opacity":0},
 1500,
 function(){$i.remove();}
 );
 e.stopPropagation();
});
</script>

改进地方

  1. 点击每次不用重新生成元素,其实改变的只有元素里面的数字而已,浪费
  2. 每次都要重新生成一个css,重复了,需要改进
  3. 点击区域应该为document,而不是body
  4. 动画执行过程中如果发生多次点击时,因为需要计数,所以要停止上一个动画的执行

改进代码

[dmengl2v]

var clickCount = 0, $i=$('<b>');
$i.css({
'z-index':99999,
'position':'absolute',
'color':'red',
'display':'none'
});
$('body').append($i);
$(document).on('click',function(e){
var x = e.pageX, y = e.pageY;
$i.text('+'+(++clickCount)).css({
'display':'block',
'top':y-15,
'left':x,
'opacity':1

}).stop(true,false).animate({
'top':y-180,
'opacity':0
},800,function(){
$i.hide();
});
e.stopPropagation();
})

[/dmengl2v]

后话

还可以给这个计数增加一个cookie,这个就是后话了。


关注我

我的微信公众号:前端开发博客,在后台回复以下关键字可以获取资源。

  • 回复「小抄」,领取Vue、JavaScript 和 WebComponent 小抄 PDF
  • 回复「Vue脑图」获取 Vue 相关脑图
  • 回复「思维图」获取 JavaScript 相关思维图
  • 回复「简历」获取简历制作建议
  • 回复「简历模板」获取精选的简历模板
  • 回复「加群」进入500人前端精英群
  • 回复「电子书」下载我整理的大量前端资源,含面试、Vue实战项目、CSS和JavaScript电子书等。
  • 回复「知识点」下载高清JavaScript知识点图谱

每日分享有用的前端开发知识,加我微信:caibaojian89 交流