javascript - 在光标位置绘制粒子的 Javascript 将粒子发送到底部
问题描述
我正在尝试使用从https://github.com/tholman/90s-cursor-effects下载的 javascript
它会在光标的位置上创建气泡粒子效果,但是当我在标签内添加一些或元素时,所有粒子都会被推到网页的底部。
这是 JavaScript 的示例代码,我对 Web 开发真的很陌生。当标签为空时,光标真正显示粒子的实际位置,但是当我包含一个部分时,粒子被一直推到底部,然后当你向下滚动到底部时,到粒子效果的距离减少但从不停留在实际光标位置。
这是我的代码。
(function bubblesCursor() {
var width = window.innerWidth;
var height = window.innerHeight;
var cursor = {
x: width / 2,
y: width / 2
};
var particles = [];
function init() {
bindEvents();
loop();
}
// Bind events that are needed
function bindEvents() {
document.addEventListener('mousemove', onMouseMove);
window.addEventListener('resize', onWindowResize);
}
function onWindowResize(e) {
width = window.innerWidth;
height = window.innerHeight;
}
function onTouchMove(e) {
if (e.touches.length > 0) {
for (var i = 0; i < e.touches.length; i++) {
addParticle(e.touches[i].clientX, e.touches[i].clientY);
}
}
}
function onMouseMove(e) {
cursor.x = e.clientX;
cursor.y = e.clientY;
addParticle(cursor.x, cursor.y);
}
function addParticle(x, y) {
var particle = new Particle();
particle.init(x, y);
particles.push(particle);
}
function updateParticles() {
// Update
for (var i = 0; i < particles.length; i++) {
particles[i].update();
}
// Remove dead particles
for (var i = particles.length - 1; i >= 0; i--) {
if (particles[i].lifeSpan < 0) {
particles[i].die();
particles.splice(i, 1);
}
}
}
function loop() {
requestAnimationFrame(loop);
updateParticles();
}
/**
* Particles
*/
function Particle() {
this.lifeSpan = 250; //ms
this.initialStyles = {
"position": "absolute",
"display": "block",
"pointerEvents": "none",
"z-index": "10000000",
"width": "5px",
"height": "5px",
"will-change": "transform",
"background": "#e6f1f7",
"box-shadow": "-1px 0px #6badd3, 0px -1px #6badd3, 1px 0px #3a92c5, 0px 1px #3a92c5",
"border-radius": "3px",
"overflow": "hidden"
};
// Init, and set properties
this.init = function(x, y) {
this.velocity = {
x: (Math.random() < 0.5 ? -1 : 1) * (Math.random() / 10),
y: (-.4 + (Math.random() * -1))
};
this.position = {
x: x - 10,
y: y - 10
};
this.element = document.createElement('span');
applyProperties(this.element, this.initialStyles);
this.update();
document.body.appendChild(this.element);
};
this.update = function() {
this.position.x += this.velocity.x;
this.position.y += this.velocity.y;
// Update velocities
this.velocity.x += (Math.random() < 0.5 ? -1 : 1) * 2 / 75;
this.velocity.y -= Math.random() / 600;
this.lifeSpan--;
this.element.style.transform = "translate3d(" + this.position.x + "px," + this.position.y + "px,0) scale(" + (0.2 + (250 - this.lifeSpan) / 250) + ")";
}
this.die = function() {
this.element.parentNode.removeChild(this.element);
}
}
/**
* Utils
*/
// Applies css `properties` to an element.
function applyProperties(target, properties) {
for (var key in properties) {
target.style[key] = properties[key];
}
}
init();
})();
解决方案
问题不在于脚本,而在于您布局 HTML 元素的方式。确保您的最顶层容器position
设置为absolute
:
<div class="parent" style="position: absolute;">
<h1>title</h1>
...
other content
...
</div>
推荐阅读
- google-sheets - 如何使用 ARRAYFORMULA 执行累积和计算
- google-cloud-run - 如何在无需添加授权令牌的情况下调用 Cloud Run 应用
- javascript - 为什么将函数导入另一个文件时函数的属性不可见?
- matlab - 如何将字符串'pi'转换为double?(MATLAB 2015a)
- html - 具有行扩展功能的 PrimeNG 数据表调用新服务并连续显示数据 Angular 5
- google-apps-script - 在 Google 表格中自动复制行
- wordpress - Wordpress - WooCommerce - 从“我的订单”页面中隐藏带有虚拟产品的订单并将其显示在自己的页面上
- serial-port - ESP32 的 Serial2 没有响应(NEO 6M GPS)
- typescript - 如何从 Typescript 中的窗口对象函数获取参数类型
- java - 引用后面序列化什么类