special effects - 鼠标移动,出现泡泡拖尾

鼠标移动,出现泡泡拖尾

一. 效果图

在这里插入图片描述

二. 实现代码

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>鼠标移动出现泡泡拖尾</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }

        html {
            background-color: #c3ecff;
        }
    </style>
</head>

<body>
    <script>
        (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",
                    "background": "#e6f1f7",
                    "box-shadow": "-1px 0px #6badd3, 0px -1px #6badd3, 1px 0px #3a92c5, 0px 1px #3a92c5",
                    "border-radius": "1px",
                    "will-change": "transform"
                };

                // 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();
        })(); 
    </script>
</body>

</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值