JS实现点击鼠标弹出自定义文字内容效果

之前看到有朋友自己搭建的博客网站,在页面任意位置点击鼠标都会弹出自定义文字,而且内容会不停变化,觉得非常炫酷,今天自己试着来实现一下这个效果。

思路分析

主要是对document添加一个click事件,每次点击会生成一个新标签,这个标签初始位置通过获取clickevent事件来获得。之后通过一个定时器setInterval实现缓慢向上的效果,然后用另一个定时器setTimeOut在一段时间后清除掉上一个定时器并且删除添加的新标签。

代码实现

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>				
	</head>
	<style type="text/css">
		* {
			margin: 0;
			padding: 0;
		}
	</style>
	<body>	
	<script type="text/javascript">
		var body = document.getElementsByTagName('body')[0];
		var textArr=["乐观", "❤" ,"积极", "向上", "自由", "正能量","(*^▽^*)", "元气满满", "开心" ,"快乐", "善良", "可爱", "暴富", "暴瘦"];
		document.addEventListener('click',(e)=>{
			// 生成字符串
			var ev = e || window.event;
			var baseX = ev.pageX;
			var baseY = ev.pageY;
			var new_span=document.createElement('span');
			new_span.innerText=textArr[parseInt(Math.random()*textArr.length)]
			new_span.style.position='fixed';
			new_span.style.left=baseX-10+'px';
			new_span.style.top=baseY+'px';
			new_span.style.color='RGB('+parseInt(Math.random()*255)+','+parseInt(Math.random()*255)+','+parseInt(Math.random()*255)+')';
			body.appendChild(new_span);
			// 定时器1实现字符串上升效果
			var timer = window.setInterval(()=>{
				new_span.style.top=parseInt(window.getComputedStyle(new_span,null)['top'])-2+'px';
				// console.log(window.getComputedStyle(new_span,null)['fontSize']);
				new_span.style.opacity=window.getComputedStyle(new_span,null)['opacity']-0.02;
				
			},30);
			// 定时器2实现字符串消失
			window.setTimeout(()=>{
				window.clearInterval(timer);
				body.removeChild(new_span);
			},1000);
		},false);

	</script>
	</body>
</html>

其中第一部分将文字的position设置为fixed是关键,这样文字可以出现在页面中任意位置。第二部分的定时器每隔30ms移动一次文字的高度以及透明度,第三部分的定时器在1秒钟之后将前面的定时器消除并删除文字。

实现效果

1-effect.gif

我是T型人小付,一位坚持终身学习的互联网从业者。喜欢我的博客欢迎在csdn上关注我,如果有问题欢迎在底下的评论区交流,谢谢。

  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值