Web实现在鼠标或点击处的文字特效
admin
2024-02-12 04:57:21
0

I’m Shendi


文章目录

  • 效果展示
  • 实现思路
  • 效果实现
    • 元素样式
    • 点击事件
      • 获取位置
      • 创建元素
      • 将元素加入document
    • 元素移动消失效果
    • 最终代码


效果展示

进入以下链接直接体验
https://sdpro.top/html/main.html


视频展示

js在鼠标点击后弹出文字特效演示



实现思路

给document增加点击事件,点击时在点击位置生成文字并使用js延时来制作动画效果


效果实现

首先生成的为文本,所以需要准备一个文本标签(当然也可以用图片标签等…)


元素样式

生成的文本在鼠标点击处,所以一般position为absolute或者fixed,absolute会影响页面,这里使用fixed

元素在其他元素上面,z-index需要给一个较大值
文本不需要换行,也不需要选中,于是css如下(也可以用js设置)

.effect_ele {position: fixed;z-index: 9999;font-size: 14px;white-space: nowrap;/* 让元素不能被选中 */-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;
}


点击事件

所有元素都能触发这个特效,所以直接给document增加点击事件

document.documentElement.addEventListener('click', function (event) {
});


获取位置

在点击事件中的 event 参数包含了点击位置信息,因为使用的 fixed,所以使用 clientX,clientY拿到位置,默认生成的位置应该在点击位置的上面一点,所以 y 默认减去一定的像素

var x = event.clientX, y = event.clientY - 10;

创建元素

特效效果为点击出现文字后文字慢慢消失并往左上/右上移动
而且元素的文字颜色/文字随机变化,于是先创建随机

// 文字列表
var texts = "Test,Shendi,Element,Javascript".split(",");
// 随机文字
var text = texts[Math.floor(Math.random()*100) % texts.length];
// 随机颜色 rgb
var r = Math.floor(Math.random()*255),g = Math.floor(Math.random()*255),b = Math.floor(Math.random()*255);

元素创建使用 document.createElement("标签名");,这里就用span标签就可以了
var ele = document.createElement("span");

文字消失需要使用到透明度(opacity),需要在js里给元素设置透明度为1 (0代表完全透明)

// 只能在js设置,在css里设置后面拿到为 undefined
ele.style.opacity = 1;

将元素初始化,为了美观一点,可以加上文字阴影

// 元素的 class 名称,指定元素样式
ele.className = "effect_ele";
// 元素默认位置
ele.style.left = x + "px";
ele.style.top = y + "px";
// 文字颜色,文字阴影
ele.style.color = "rgb(" +r+ "," +g+ "," +b+ ")";
ele.style.textShadow = "5px 3px 1px rgba(" +r+ "," +g+ "," +b+ ",0.4)";
//  元素内容
ele.innerText = text;

将元素加入document

创建完元素后需要将元素加入文档才能显示,使用 appendChild 函数,函数返回添加后的元素引用

在点击事件中直接使用 this.appendChild

// 这里的元素实例需要保存,后面需要改变元素位置等
var eleInst = this.appendChild(ele);


元素移动消失效果

往上移动,左右则随机,每次移动都减少一点透明度,透明度减完则删除元素,因需要递归,所以封装了一个函数,代码如下

// 参数1为创建的元素引用,参数4为方向
function textAnim(ele, x, y, direction) {// 往上移动,并减少opacity,直至opacity<=0则移除setTimeout(function () {if (ele.style.opacity <= 0) {document.documentElement.removeChild(ele);return;}y -= 1.2;if (direction == 0) {x += 1;} else {x -= 1;}ele.style.top = y + "px";ele.style.left = x + "px";ele.style.opacity = ele.style.opacity - 0.02;textAnim(ele, x, y, direction);}, 11);
}

最终代码

最终代码如下

/*** 实际使用为了避免意外,用 try catch 盖住* @author Shendi*/
try {var texts = "Test,Shendi,Element,Javascript".split(",");document.documentElement.addEventListener('click', function (event) {var x = event.clientX, y = event.clientY - 10;var ele = document.createElement("span");ele.className = "effect_ele";ele.style.left = x + "px";ele.style.top = y + "px";// 只能在这设置,在css里就拿不到了ele.style.opacity = 1;var r = Math.floor(Math.random()*255),g = Math.floor(Math.random()*255),b = Math.floor(Math.random()*255);ele.style.color = "rgb(" +r+ "," +g+ "," +b+ ")";ele.style.textShadow = "5px 3px 1px rgba(" +r+ "," +g+ "," +b+ ",0.4)";ele.innerText = texts[Math.floor(Math.random()*100) % texts.length];textAnim(this.appendChild(ele), x, y, Math.floor(Math.random()*10)%2);});/* direction 1左 0右 */function textAnim(ele, x, y, direction) {// 往上移动,并减少opacity,直至opacity<=0则移除setTimeout(function () {if (ele.style.opacity <= 0) {document.documentElement.removeChild(ele);return;}y -= 1.2;if (direction == 0) {x += 1;} else {x -= 1;}ele.style.top = y + "px";ele.style.left = x + "px";ele.style.opacity = ele.style.opacity - 0.02;textAnim(ele, x, y, direction);}, 11);}
} catch (e) {console.log(e);
}


一键三连嘛?

上一篇:Vim基础使用

下一篇:pandas drop 方法

相关内容

热门资讯

安卓如何操控苹果系统,揭秘跨平... 你知道吗?在这个科技飞速发展的时代,安卓和苹果两大操作系统之间的较量可是从未停歇。虽然它们各自有着忠...
安卓系统账户同步数据,畅享无缝... 你有没有遇到过这种情况:手机里存了那么多宝贝照片、重要文件,结果换了个新手机,却发现那些宝贝全都不翼...
安卓系统不停推送广告,安卓系统... 你有没有发现,最近你的安卓手机是不是越来越“热情”了?没错,就是那个不停在你屏幕上跳来跳去的广告!今...
airpods可以和安卓系统,... 你有没有想过,那些炫酷的AirPods竟然也能和安卓手机完美搭配?没错,就是那个我们平时只听说和iP...
安卓系统实体键盘不对,创新与挑... 你是不是也遇到了这个问题?安卓手机的实体键盘突然不对劲了,按下去没反应,或者反应迟钝,简直让人抓狂!...
汽车导航改装安卓系统,安卓系统... 你有没有想过,你的汽车导航系统是不是已经out了?现在,让我来给你揭秘如何给你的爱车来一次科技大变身...
安卓系统如何限制下载,安卓系统... 你有没有发现,手机里的安卓系统越来越智能了?不过,这也意味着有时候我们不小心就会下载一些不想要的软件...
安卓系统调成日语,概要の副標題... 你有没有想过,你的安卓手机竟然可以变成一个日式小天地呢?没错,就是那种动漫里常见的日语界面,是不是听...
男生耳机推荐安卓系统,男生耳机... 耳机可是现代生活中不可或缺的小玩意儿,尤其是对于喜欢听音乐的男生来说,一副好耳机简直就是灵魂的伴侣。...
安卓同版本升级系统,功能优化与... 你知道吗?最近手机界可是热闹非凡呢!各大品牌纷纷推出了安卓同版本升级系统,让我们的手机焕然一新。今天...
安卓更换别的手机系统,轻松切换... 你有没有想过,你的安卓手机用久了,是不是有点审美疲劳了呢?或者,你最近是不是对其他手机系统产生了浓厚...
安卓系统单机神雕侠侣,指尖重温 你有没有想过,在手机上也能体验一把江湖恩怨、侠骨柔肠?没错,就是那个让人心驰神往的《神雕侠侣》!今天...
安卓系统键盘语言切换,安卓系统... 你有没有发现,手机上的安卓系统键盘语言切换功能,简直就像是个神奇的魔法棒,轻轻一点,就能让文字飞舞在...
oppok1安卓系统,性能与体... 你有没有发现,最近手机圈里又掀起了一股热潮?没错,就是OPPO K1这款新机!这款手机不仅外观时尚,...
安卓系统环境的搭建,从零开始构... 想要在电脑上体验安卓系统的魅力,是不是已经跃跃欲试了呢?别急,今天就来手把手教你如何搭建一个属于自己...
【MySQL】锁 锁 文章目录锁全局锁表级锁表锁元数据锁(MDL)意向锁AUTO-INC锁...
【内网安全】 隧道搭建穿透上线... 文章目录内网穿透-Ngrok-入门-上线1、服务端配置:2、客户端连接服务端ÿ...
GCN的几种模型复现笔记 引言 本篇笔记紧接上文,主要是上一篇看写了快2w字,再去接入代码感觉有点...
数据分页展示逻辑 import java.util.Arrays;import java.util.List;impo...
Redis为什么选择单线程?R... 目录专栏导读一、Redis版本迭代二、Redis4.0之前为什么一直采用单线程?三、R...