十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
使用JavaScript怎么实现一个鼠标拖尾效果?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

JS 代码
function getMousePos(event) {
var e = event || window.event;
var mouseInfo = {
mouseX : e.clientX,
mouseY : e.clientY
}
return mouseInfo;
}
function getMouseArt() {
this.artStyle = {
position: "fixed",
top: 0,
left: 0,
width: "50px",
height: "50px",
"font-size": 0,
"color": 0,
"text-transform": 0
};
this.init = function(obj) {
var character = ["你", "真", "的", "爱", "我", "吗", "喜", "欢", "不", "对", "起", "彩", "色", "世", "界", "灰", "?"];
var font_trans = ["uppercase", "lowercase"];
this.Alpha = 1;
this.element = document.createElement('div');
var text = document.createTextNode(character[Math.floor(Math.random() * character.length)]);
this.element.appendChild(text);
this.addStyle(this.element, this.artStyle);
var offsetV = Math.floor(Math.random() * 60 - 30); // -30 ~ 30
this.element.style.left = obj.mouseX + offsetV +"px"; // x
this.element.style.top = obj.mouseY + offsetV +"px"; // y
this.element.style.fontSize = Math.floor(Math.random() * 20 + 10) + "px";
this.element.style.color = "hsla("+ Math.floor(Math.random() * 255) + ",100%,50%," + this.Alpha + ")";
this.element.style.textTransform = font_trans[Math.floor(Math.random() * 2)];
document.body.appendChild(this.element);
}
this.addStyle = function(ele, genuine) {
for (var k in genuine) {
ele.style[k] = genuine[k];
}
}
this.delElement = function() {
document.body.removeChild(this.element);
}
this.reduceColor = function(win) {
if (this.Alpha <= 1 && this.Alpha > 0) {
this.Alpha = this.Alpha - 0.1;
this.element.style.color = "hsla("+ Math.floor(Math.random() * 255) + ",100%,50%," + this.Alpha + ")";
console.log(this.Alpha);
}
else {
clearInterval(win);
this.delElement();
}
}
}
document.onmousemove = function(event) {
var obj = getMousePos(event);
var art = new getMouseArt();
art.init(obj);
var win = setInterval(function() {
art.reduceColor(win);
}, 30);
}HTML 代码
Document
关于使用JavaScript怎么实现一个鼠标拖尾效果问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。