您现在的位置是:群英 > 开发技术 > web开发
使用JS实现十类美观的页面动态效果
Admin发表于 2022-05-26 17:28:31588 次浏览
相信很多人对“使用JS实现十类美观的页面动态效果”都不太了解,下面群英小编为你详细解释一下这个问题,希望对你有一定的帮助

1、鼠标点击弹出爱心

代码

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>document</title>
</head>
 
<body>
    <!-- 网页鼠标点击特效(爱心) -->
    <script type="text/javascript">
         ! function (e, t, a) {
            function r() {
                for (var e = 0; e < s.length; e++) s[e].alpha <= 0 ? (t.body.removechild(s[e].el), s.splice(e, 1)) : (s[
                        e].y--, s[e].scale += .004, s[e].alpha -= .013, s[e].el.style.csstext = "left:" + s[e].x +
                    "px;top:" + s[e].y + "px;opacity:" + s[e].alpha + ";transform:scale(" + s[e].scale + "," + s[e]
                    .scale + ") rotate(45deg);background:" + s[e].color + ";z-index:99999");
                requestanimationframe(r)
            }
 
            function n() {
                var t = "function" == typeof e.onclick && e.onclick;
                e.onclick = function (e) {
                    t && t(), o(e)
                }
            }
 
            function o(e) {
                var a = t.createelement("div");
                a.classname = "heart", s.push({
                    el: a,
                    x: e.clientx - 5,
                    y: e.clienty - 5,
                    scale: 1,
                    alpha: 1,
                    color: c()
                }), t.body.appendchild(a)
            }
 
            function i(e) {
                var a = t.createelement("style");
                a.type = "text/css";
                try {
                    a.appendchild(t.createtextnode(e))
                } catch (t) {
                    a.stylesheet.csstext = e
                }
                t.getelementsbytagname("head")[0].appendchild(a)
            }
 
            function c() {
                return "rgb(" + ~~(255 * math.random()) + "," + ~~(255 * math.random()) + "," + ~~(255 * math
                    .random()) + ")"
            }
            var s = [];
            e.requestanimationframe = e.requestanimationframe || e.webkitrequestanimationframe || e
                .mozrequestanimationframe || e.orequestanimationframe || e.msrequestanimationframe || function (e) {
                    settimeout(e, 1e3 / 60)
                }, i(
                    ".heart{width: 10px;height: 10px;position: fixed;background: #f00;transform: rotate(45deg);-webkit-transform: rotate(45deg);-moz-transform: rotate(45deg);}.heart:after,.heart:before{content: '';width: inherit;height: inherit;background: inherit;border-radius: 50%;-webkit-border-radius: 50%;-moz-border-radius: 50%;position: fixed;}.heart:after{top: -5px;}.heart:before{left: -5px;}"
                ), n(), r()
        }(window, document);
    </script>
</body>
 
</html>

2、鼠标点击弹出文字

代码

<!doctype html>
<html lang="en">
 
<head>
    <meta charset="utf-8">
    <title>document</title>
</head>
 
<body>
    <script>
        (function () {
            var a_idx = 0;
            window.onclick = function (event) {
                var a = new array("富强", "民主", "文明", "和谐", "自由", "平等", "公正", "法治", "爱国",
                    "敬业", "诚信", "友善");
 
                var heart = document.createelement("b"); //创建b元素
                heart.onselectstart = new function('event.returnvalue=false'); //防止拖动
 
                document.body.appendchild(heart).innerhtml = a[a_idx]; //将b元素添加到页面上
                a_idx = (a_idx + 1) % a.length;
                heart.style.csstext = "position: fixed;left:-100%;"; //给p元素设置样式
 
                var f = 16, // 字体大小
                    x = event.clientx - f / 2, // 横坐标
                    y = event.clienty - f, // 纵坐标
                    c = randomcolor(), // 随机颜色
                    a = 1, // 透明度
                    s = 1.2; // 放大缩小
 
                var timer = setinterval(function () { //添加定时器
                    if (a <= 0) {
                        document.body.removechild(heart);
                        clearinterval(timer);
                    } else {
                        heart.style.csstext = "font-size:16px;cursor: default;position: fixed;color:" +
                            c + ";left:" + x + "px;top:" + y + "px;opacity:" + a + ";transform:scale(" +
                            s + ");";
 
                        y--;
                        a -= 0.016;
                        s += 0.002;
                    }
                }, 15)
 
            }
            // 随机颜色
            function randomcolor() {
 
                return "rgb(" + (~~(math.random() * 255)) + "," + (~~(math.random() * 255)) + "," + (~~(math
                .random() * 255)) + ")";
 
            }
        }());
    </script>
</body>
 
</html>

3、鼠标点击弹出烟花波纹

代码

<html>
<head>
 
</head>
<body>
<script>
function clickeffect() {
  let balls = [];
  let longpressed = false;
  let longpress;
  let multiplier = 0;
  let width, height;
  let origin;
  let normal;
  let ctx;
  const colours = ["#f73859", "#14ffec", "#00e0ff", "#ff99fe", "#faf15d"];
  const canvas = document.createelement("canvas");
  document.body.appendchild(canvas);
  canvas.setattribute("style", "width: 100%; height: 100%; top: 0; left: 0; z-index: 99999; position: fixed; pointer-events: none;");
  const pointer = document.createelement("span");
  pointer.classlist.add("pointer");
  document.body.appendchild(pointer);
 
  if (canvas.getcontext && window.addeventlistener) {
    ctx = canvas.getcontext("2d");
    updatesize();
    window.addeventlistener('resize', updatesize, false);
    loop();
    window.addeventlistener("mousedown", function(e) {
      pushballs(randbetween(10, 20), e.clientx, e.clienty);
      document.body.classlist.add("is-pressed");
      longpress = settimeout(function(){
        document.body.classlist.add("is-longpress");
        longpressed = true;
      }, 500);
    }, false);
    window.addeventlistener("mouseup", function(e) {
      clearinterval(longpress);
      if (longpressed == true) {
        document.body.classlist.remove("is-longpress");
        pushballs(randbetween(50 + math.ceil(multiplier), 100 + math.ceil(multiplier)), e.clientx, e.clienty);
        longpressed = false;
      }
      document.body.classlist.remove("is-pressed");
    }, false);
    window.addeventlistener("mousemove", function(e) {
      let x = e.clientx;
      let y = e.clienty;
      pointer.style.top = y + "px";
      pointer.style.left = x + "px";
    }, false);
  } else {
    console.log("canvas or addeventlistener is unsupported!");
  }
 
 
  function updatesize() {
    canvas.width = window.innerwidth * 2;
    canvas.height = window.innerheight * 2;
    canvas.style.width = window.innerwidth + 'px';
    canvas.style.height = window.innerheight + 'px';
    ctx.scale(2, 2);
    width = (canvas.width = window.innerwidth);
    height = (canvas.height = window.innerheight);
    origin = {
      x: width / 2,
      y: height / 2
    };
    normal = {
      x: width / 2,
      y: height / 2
    };
  }
  class ball {
    constructor(x = origin.x, y = origin.y) {
      this.x = x;
      this.y = y;
      this.angle = math.pi * 2 * math.random();
      if (longpressed == true) {
        this.multiplier = randbetween(14 + multiplier, 15 + multiplier);
      } else {
        this.multiplier = randbetween(6, 12);
      }
      this.vx = (this.multiplier + math.random() * 0.5) * math.cos(this.angle);
      this.vy = (this.multiplier + math.random() * 0.5) * math.sin(this.angle);
      this.r = randbetween(8, 12) + 3 * math.random();
      this.color = colours[math.floor(math.random() * colours.length)];
    }
    update() {
      this.x += this.vx - normal.x;
      this.y += this.vy - normal.y;
      normal.x = -2 / window.innerwidth * math.sin(this.angle);
      normal.y = -2 / window.innerheight * math.cos(this.angle);
      this.r -= 0.3;
      this.vx *= 0.9;
      this.vy *= 0.9;
    }
  }
 
  function pushballs(count = 1, x = origin.x, y = origin.y) {
    for (let i = 0; i < count; i++) {
      balls.push(new ball(x, y));
    }
  }
 
  function randbetween(min, max) {
    return math.floor(math.random() * max) + min;
  }
 
  function loop() {
    ctx.fillstyle = "rgba(255, 255, 255, 0)";
    ctx.clearrect(0, 0, canvas.width, canvas.height);
    for (let i = 0; i < balls.length; i++) {
      let b = balls[i];
      if (b.r < 0) continue;
      ctx.fillstyle = b.color;
      ctx.beginpath();
      ctx.arc(b.x, b.y, b.r, 0, math.pi * 2, false);
      ctx.fill();
      b.update();
    }
    if (longpressed == true) {
      multiplier += 0.2;
    } else if (!longpressed && multiplier >= 0) {
      multiplier -= 0.4;
    }
    removeball();
    requestanimationframe(loop);
  }
 
  function removeball() {
    for (let i = 0; i < balls.length; i++) {
      let b = balls[i];
      if (b.x + b.r < 0 || b.x - b.r > width || b.y + b.r < 0 || b.y - b.r > height || b.r < 0) {
        balls.splice(i, 1);
      }
    }
  }
}
clickeffect();//调用特效函数
</script>
</body>
</html>

4、鼠标小星星拖尾跟随

代码

<!doctype html>
<html lang="en">
 
<head>
    
</head>
 
<body>
    <span class="js-cursor-container"></span>
    <script>
        (function fairydustcursor() {
 
            var possiblecolors = ["#d61c59", "#e7d84b", "#1b8798"]
            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 onmousemove(e) {
                cursor.x = e.clientx;
                cursor.y = e.clienty;
 
                addparticle(cursor.x, cursor.y, possiblecolors[math.floor(math.random() * possiblecolors.length)]);
            }
 
            function addparticle(x, y, color) {
                var particle = new particle();
                particle.init(x, y, color);
                particles.push(particle);
            }
 
            function updateparticles() {
 
                // updated
                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.character = "*";
                this.lifespan = 120; //ms
                this.initialstyles = {
                    "position": "fixed",
                    "display": "inline-block",
                    "top": "0px",
                    "left": "0px",
                    "pointerevents": "none",
                    "touch-action": "none",
                    "z-index": "10000000",
                    "fontsize": "25px",
                    "will-change": "transform"
                };
 
                // init, and set properties
                this.init = function (x, y, color) {
 
                    this.velocity = {
                        x: (math.random() < 0.5 ? -1 : 1) * (math.random() / 2),
                        y: 1
                    };
 
                    this.position = { x: x + 10, y: y + 10 };
                    this.initialstyles.color = color;
 
                    this.element = document.createelement('span');
                    this.element.innerhtml = this.character;
                    applyproperties(this.element, this.initialstyles);
                    this.update();
 
                    document.queryselector('.js-cursor-container').appendchild(this.element);
                };
 
                this.update = function () {
                    this.position.x += this.velocity.x;
                    this.position.y += this.velocity.y;
                    this.lifespan--;
 
                    this.element.style.transform = "translate3d(" + this.position.x + "px," + this.position.y + "px, 0) scale(" + (this.lifespan / 120) + ")";
                }
 
                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];
                }
            }
 
            if (!('ontouchstart' in window || navigator.msmaxtouchpoints)) init();
        })();    
    </script>
</body>
 
</html>

5、鼠标粒子随心拖尾跟随

代码

<!doctype html>
<html>
  <head>
    <meta charset="utf-8" />
    <title>粒子随心动画</title>
    <script src="http://cdn.sucai8.cn/cdn/jquery/jquery-1.10.2.js"></script>
    <style>
      body {
        overflow: hidden;
        margin: 0;
      }
 
      .twitter:hover a {
        transform: rotate(-45deg) scale(1.05);
      }
      .twitter:hover i {
        color: #21c2ff;
      }
      .twitter a {
        bottom: -40px;
        right: -75px;
        transform: rotate(-45deg);
      }
      .twitter i {
        bottom: 7px;
        right: 7px;
        color: #00aced;
      }
 
      .social-icon a {
        position: absolute;
        background: white;
        color: white;
        box-shadow: -1px -1px 20px 0px rgba(0, 0, 0, 0.3);
        display: inline-block;
        width: 150px;
        height: 80px;
        transform-origin: 50% 50%;
        transition: 0.15s ease-out;
      }
      .social-icon i {
        position: absolute;
        pointer-events: none;
        z-index: 1000;
        transition: 0.15s ease-out;
      }
 
      .youtube:hover a {
        transform: rotate(45deg) scale(1.05);
      }
      .youtube:hover i {
        color: #ec4c44;
      }
      .youtube a {
        bottom: -40px;
        left: -75px;
        transform: rotate(45deg);
      }
      .youtube i {
        bottom: 7px;
        left: 7px;
        color: #e62117;
      }
    </style>
  </head>
  <body>
    <canvas></canvas>
 
    <script>
      "use strict";
 
      // initial setup
      var canvas = document.queryselector("canvas");
      var c = canvas.getcontext("2d");
 
      canvas.width = innerwidth;
      canvas.height = innerheight;
 
      // variables
      var mouse = {
        x: innerwidth / 2,
        y: innerheight / 2 - 80,
      };
 
      var colors = ["#00bdff", "#4d39ce", "#088eff"];
 
      // event listeners
      addeventlistener("mousemove", function (event) {
        mouse.x = event.clientx;
        mouse.y = event.clienty;
      });
 
      addeventlistener("resize", function () {
        canvas.width = innerwidth;
        canvas.height = innerheight;
 
        init();
      });
 
      // utility functions
      function randomintfromrange(min, max) {
        return math.floor(math.random() * (max - min + 1) + min);
      }
 
      function randomcolor(colors) {
        return colors[math.floor(math.random() * colors.length)];
      }
 
      // objects
      function particle(x, y, radius, color) {
        var _this = this;
 
        var distance = randomintfromrange(50, 120);
        this.x = x;
        this.y = y;
        this.radius = radius;
        this.color = color;
        this.radians = math.random() * math.pi * 2;
        this.velocity = 0.05;
        this.distancefromcenter = {
          x: distance,
          y: distance,
        };
        this.prevdistancefromcenter = {
          x: distance,
          y: distance,
        };
        this.lastmouse = { x: x, y: y };
 
        this.update = function () {
          var lastpoint = { x: _this.x, y: _this.y };
          // move points over time
          _this.radians += _this.velocity;
 
          // drag effect
          _this.lastmouse.x += (mouse.x - _this.lastmouse.x) * 0.05;
          _this.lastmouse.y += (mouse.y - _this.lastmouse.y) * 0.05;
 
          // circular motion
          _this.distancefromcenter.x =
            _this.prevdistancefromcenter.x + math.sin(_this.radians) * 100;
          _this.distancefromcenter.y =
            _this.prevdistancefromcenter.x + math.sin(_this.radians) * 100;
 
          _this.x =
            _this.lastmouse.x +
            math.cos(_this.radians) * _this.distancefromcenter.x;
          _this.y =
            _this.lastmouse.y +
            math.sin(_this.radians) * _this.distancefromcenter.y;
 
          _this.draw(lastpoint);
        };
 
        this.draw = function (lastpoint) {
          c.beginpath();
          c.strokestyle = _this.color;
          c.linewidth = _this.radius;
          c.moveto(lastpoint.x, lastpoint.y);
          c.lineto(_this.x, _this.y);
          c.stroke();
          c.closepath();
        };
      }
 
      // implementation
      var particles = undefined;
      function init() {
        particles = [];
 
        for (var i = 0; i < 50; i++) {
          var radius = math.random() * 2 + 1;
          particles.push(
            new particle(
              canvas.width / 2,
              canvas.height / 2,
              radius,
              randomcolor(colors)
            )
          );
        }
      }
 
      // animation loop
      function animate() {
        requestanimationframe(animate);
        c.fillstyle = "rgba(255, 255, 255, 0.05)";
        c.fillrect(0, 0, canvas.width, canvas.height);
 
        particles.foreach(function (particle) {
          particle.update();
        });
      }
 
      init();
      animate();
    </script>
  </body>
</html>
 

6、鼠标笑脸跟随+仙女棒+泡泡+雪花+点击烟花效果(自由组合)

代码

<!doctype html>
<html lang="en">
 
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>document</title>
</head>
 
<body>
    <!--光标特效仙女棒-->
    <script src="https://blog-static.cnblogs.com/files/axqa/fairydustcursor.js"></script>
    <!--光标之泡泡-->
    <script src="https://blog-static.cnblogs.com/files/axqa/bubblecursor.js"></script>
    <!--笑脸-->
    <script src="https://blog-static.cnblogs.com/files/axqa/emojicursor.js"></script>
    <!--雪花-->
    <script src="https://blog-static.cnblogs.com/files/axqa/snowflakecursor.js"></script>
    <!-- 点击后出现烟花效果 -->
    <script src="https://blog-static.cnblogs.com/files/axqa/cursor-effects.js"></script>
 
</body>
 
</html>

7、樱花特效

代码

<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<title></title>
</head>
 
<body>
</body>
 
<script>
            var stop, staticx;
			var img = new image();
			img.src = "";
 
			function sakura(x, y, s, r, fn) {
				this.x = x;
				this.y = y;
				this.s = s;
				this.r = r;
				this.fn = fn;
			}
 
			sakura.prototype.draw = function(cxt) {
				cxt.save();
				var xc = 40 * this.s / 4;
				cxt.translate(this.x, this.y);
				cxt.rotate(this.r);
				cxt.drawimage(img, 0, 0, 40 * this.s, 40 * this.s)
				cxt.restore();
			}
 
			sakura.prototype.update = function() {
				this.x = this.fn.x(this.x, this.y);
				this.y = this.fn.y(this.y, this.y);
				this.r = this.fn.r(this.r);
				if(this.x > window.innerwidth ||
					this.x < 0 ||
					this.y > window.innerheight ||
					this.y < 0
				) {
					this.r = getrandom('fnr');
					if(math.random() > 0.4) {
						this.x = getrandom('x');
						this.y = 0;
						this.s = getrandom('s');
						this.r = getrandom('r');
					} else {
						this.x = window.innerwidth;
						this.y = getrandom('y');
						this.s = getrandom('s');
						this.r = getrandom('r');
					}
				}
			}
 
			sakuralist = function() {
				this.list = [];
			}
			sakuralist.prototype.push = function(sakura) {
				this.list.push(sakura);
			}
			sakuralist.prototype.update = function() {
				for(var i = 0, len = this.list.length; i < len; i++) {
					this.list[i].update();
				}
			}
			sakuralist.prototype.draw = function(cxt) {
				for(var i = 0, len = this.list.length; i < len; i++) {
					this.list[i].draw(cxt);
				}
			}
			sakuralist.prototype.get = function(i) {
				return this.list[i];
			}
			sakuralist.prototype.size = function() {
				return this.list.length;
			}
 
			function getrandom(option) {
				var ret, random;
				switch(option) {
					case 'x':
						ret = math.random() * window.innerwidth;
						break;
					case 'y':
						ret = math.random() * window.innerheight;
						break;
					case 's':
						ret = math.random();
						break;
					case 'r':
						ret = math.random() * 6;
						break;
					case 'fnx':
						random = -0.5 + math.random() * 1;
						ret = function(x, y) {
							return x + 0.5 * random - 1.7;
						};
						break;
					case 'fny':
						random = 1.5 + math.random() * 0.7
						ret = function(x, y) {
							return y + random;
						};
						break;
					case 'fnr':
						random = math.random() * 0.03;
						ret = function(r) {
							return r + random;
						};
						break;
				}
				return ret;
			}
 
			function startsakura() {
 
				requestanimationframe = window.requestanimationframe ||
					window.mozrequestanimationframe ||
					window.webkitrequestanimationframe ||
					window.msrequestanimationframe ||
					window.orequestanimationframe;
				var canvas = document.createelement('canvas'),
					cxt;
				staticx = true;
				canvas.height = window.innerheight;
				canvas.width = window.innerwidth;
				canvas.setattribute('style', 'position: fixed;left: 0;top: 0;pointer-events: none;');
				canvas.setattribute('id', 'canvas_sakura');
				document.getelementsbytagname('body')[0].appendchild(canvas);
				cxt = canvas.getcontext('2d');
				var sakuralist = new sakuralist();
				for(var i = 0; i < 50; i++) {
					var sakura, randomx, randomy, randoms, randomr, randomfnx, randomfny;
					randomx = getrandom('x');
					randomy = getrandom('y');
					randomr = getrandom('r');
					randoms = getrandom('s');
					randomfnx = getrandom('fnx');
					randomfny = getrandom('fny');
					randomfnr = getrandom('fnr');
					sakura = new sakura(randomx, randomy, randoms, randomr, {
						x: randomfnx,
						y: randomfny,
						r: randomfnr
					});
					sakura.draw(cxt);
					sakuralist.push(sakura);
				}
				stop = requestanimationframe(function() {
					cxt.clearrect(0, 0, canvas.width, canvas.height);
					sakuralist.update();
					sakuralist.draw(cxt);
					stop = requestanimationframe(arguments.callee);
				})
			}
 
			window.onresize = function() {
				var canvassnow = document.getelementbyid('canvas_snow');
				canvassnow.width = window.innerwidth;
				canvassnow.height = window.innerheight;
			}
 
			img.onload = function() {
				startsakura();
			}
 
			function stopp() {
				if(staticx) {
					var child = document.getelementbyid("canvas_sakura");
					child.parentnode.removechild(child);
					window.cancelanimationframe(stop);
					staticx = false;
				} else {
					startsakura();
				}
			}
</script>
</html>

8、蜘蛛网特效

代码

!function () {
    function n(n, e, t) {
        return n.getattribute(e) || t
    }
 
    function e(n) {
        return document.getelementsbytagname(n)
    }
 
    function t() {
        var t = e("script"), o = t.length, i = t[o - 1];
        return {l: o, z: n(i, "zindex", -1), o: n(i, "opacity", .5), c: n(i, "color", "0,0,0"), n: n(i, "count", 99)}
    }
 
    function o() {
        a = m.width = window.innerwidth || document.documentelement.clientwidth || document.body.clientwidth, c = m.height = window.innerheight || document.documentelement.clientheight || document.body.clientheight
    }
 
    function i() {
        r.clearrect(0, 0, a, c);
        var n, e, t, o, m, l;
        s.foreach(function (i, x) {
            for (i.x += i.xa, i.y += i.ya, i.xa *= i.x > a || i.x < 0 ? -1 : 1, i.ya *= i.y > c || i.y < 0 ? -1 : 1, r.fillrect(i.x - .5, i.y - .5, 1, 1), e = x + 1; e < u.length; e++) n = u[e], null !== n.x && null !== n.y && (o = i.x - n.x, m = i.y - n.y, l = o * o + m * m, l < n.max && (n === y && l >= n.max / 2 && (i.x -= .03 * o, i.y -= .03 * m), t = (n.max - l) / n.max, r.beginpath(), r.linewidth = t / 2, r.strokestyle = "rgba(" + d.c + "," + (t + .2) + ")", r.moveto(i.x, i.y), r.lineto(n.x, n.y), r.stroke()))
        }), x(i)
    }
 
    var a, c, u, m = document.createelement("canvas"), d = t(), l = "c_n" + d.l, r = m.getcontext("2d"),
        x = window.requestanimationframe || window.webkitrequestanimationframe || window.mozrequestanimationframe || window.orequestanimationframe || window.msrequestanimationframe || function (n) {
            window.settimeout(n, 1e3 / 45)
        }, w = math.random, y = {x: null, y: null, max: 2e4};
    m.id = l, m.style.csstext = "position:fixed;top:0;left:0;z-index:" + d.z + ";opacity:" + d.o, e("body")[0].appendchild(m), o(), window.onresize = o, window.onmousemove = function (n) {
        n = n || window.event, y.x = n.clientx, y.y = n.clienty
    }, window.onmouseout = function () {
        y.x = null, y.y = null
    };
    for (var s = [], f = 0; d.n > f; f++) {
        var h = w() * a, g = w() * c, v = 2 * w() - 1, p = 2 * w() - 1;
        s.push({x: h, y: g, xa: v, ya: p, max: 6e3})
    }
    u = s.concat([y]), settimeout(function () {
        i()
    }, 100)
}();

9、看板娘(左下角的小人)

代码(直接引入js文件即可)

<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/font-awesome/css/font-awesome.min.css">
	<link rel="stylesheet" href="https://cdn.jsdelivr.net/semantic-ui/2.2.4/semantic.min.css">
        <script src="https://cdn.jsdelivr.net/npm/jquery@3.2/dist/jquery.min.js"></script>
	<script src="https://cdn.jsdelivr.net/semantic-ui/2.2.4/semantic.min.js"></script>
	<script src="https://cdn.jsdelivr.net/npm/jquery.scrollto@2.1.2/jquery.scrollto.min.js"></script>
	<script src="https://cdn.jsdelivr.net/gh/stevenjoezhang/live2d-widget@latest/autoload.js"></script>

10、烟花

代码

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>逼真的烟花</title>
<script src="js/jquery.min.js"></script>
<style>
body {
  margin: 0;
  padding: 0;
  background: #000000;
  overflow: hidden;
}
</style>
</head>
<body>
<canvas id="canvas"></canvas>
<!-- best viewed in chrome -->
 
<script>
// fun options!
const particles_per_firework = 150; // 100 - 400 or try 1000
const firework_chance = 0.02; // percentage, set to 0 and click instead
const base_particle_speed = 0.6; // between 0-4, controls the size of the overall fireworks
const firework_lifespan = 600; // ms
const particle_initial_speed = 4.5; // 2-8
 
// not so fun options =\
const gravity = 9.8;
 
 
const canvas = document.getelementbyid('canvas');
const ctx = canvas.getcontext('2d');
 
let particles = [];
let disableautofireworks = false;
let resetdisable = 0;
 
let loop = () => {
  
  if (!disableautofireworks && math.random() < firework_chance) {
    createfirework();
  }
  
  ctx.clearrect(0, 0, canvas.width, canvas.height);
  
  particles.foreach((particle, i) => {
    particle.animate();
    particle.render();
    if (particle.y > canvas.height 
        || particle.x < 0 
        || particle.x > canvas.width
        || particle.alpha <= 0
       ) {
      particles.splice(i, 1);
    }
  });
  
  requestanimationframe(loop);
  
};
 
let createfirework = (
    x = math.random() * canvas.width,
    y = math.random() * canvas.height
  ) => {
  
  let speed = (math.random() * 2) + base_particle_speed;
  let maxspeed = speed;
 
  let red = ~~(math.random() * 255);
  let green = ~~(math.random() * 255);
  let blue = ~~(math.random() * 255);
  
  // use brighter colours
  red = (red < 150 ? red + 150 : red);
  green = (green < 150 ? green + 150 : green);
  blue = (blue < 150 ? blue + 150 : blue);
 
  // inner firework
  for (let i = 0; i < particles_per_firework; i++) {
    let particle = new particle(x, y, red, green, blue, speed);
    particles.push(particle);
 
    maxspeed = (speed > maxspeed ? speed : maxspeed);
  }
 
  // outer edge particles to make the firework appear more full
  for (let i = 0; i < 40; i++) {
    let particle = new particle(x, y, red, green, blue, maxspeed, true);
    particles.push(particle);
  }
  
};
 
class particle {
  
  constructor(
    x = 0,
    y = 0, 
    red = ~~(math.random() * 255), 
    green = ~~(math.random() * 255), 
    blue = ~~(math.random() * 255), 
    speed, 
    isfixedspeed
  ) {
    
    this.x = x;
    this.y = y;
    this.red = red;
    this.green = green;
    this.blue = blue;
    this.alpha = 0.05;
    this.radius = 1 + math.random();
    this.angle = math.random() * 360;
    this.speed = (math.random() * speed) + 0.1;
    this.velocityx = math.cos(this.angle) * this.speed;
    this.velocityy = math.sin(this.angle) * this.speed;
    this.starttime = (new date()).gettime();
    this.duration = math.random() * 300 + firework_lifespan;
    this.currentdiration = 0;
    this.dampening = 30; // slowing factor at the end
    
    this.colour = this.getcolour();
    
    if (isfixedspeed) {
      this.speed = speed;
      this.velocityy = math.sin(this.angle) * this.speed;
      this.velocityx = math.cos(this.angle) * this.speed;
    }
    
    this.initialvelocityx = this.velocityx;
    this.initialvelocityy = this.velocityy;
 
  }
  
  animate() {
    
    this.currentduration = (new date()).gettime() - this.starttime;
    
    // initial speed kick
    if (this.currentduration <= 200) {
      
      this.x += this.initialvelocityx * particle_initial_speed;
      this.y += this.initialvelocityy * particle_initial_speed;
      this.alpha += 0.01;
 
      this.colour = this.getcolour(240, 240, 240, 0.9);
      
    } else {
      
      // normal expansion
      this.x += this.velocityx;
      this.y += this.velocityy;
      this.colour = this.getcolour(this.red, this.green, this.blue, 0.4 + (math.random() * 0.3));
      
    }
    
    this.velocityy += gravity / 1000;
    
    // slow down particles at the end
    if (this.currentduration >= this.duration) {
      this.velocityx -= this.velocityx / this.dampening; 
      this.velocityy -= this.velocityy / this.dampening;
    }
    
    if (this.currentduration >= this.duration + this.duration / 1.1) {
      
      // fade out at the end
      this.alpha -= 0.02;
      this.colour = this.getcolour();
      
    } else {
      
      // fade in during expansion
      if (this.alpha < 1) {
        this.alpha += 0.03;
      }
      
    }
  }
  
  render() {
    
    ctx.beginpath();
    ctx.arc(this.x, this.y, this.radius, 0, math.pi * 2, true);
    ctx.linewidth = this.linewidth;
    ctx.fillstyle = this.colour;
    ctx.shadowblur = 8;
    ctx.shadowcolor = this.getcolour(this.red + 150, this.green + 150, this.blue + 150, 1);
    ctx.fill();
    
  }
  
  getcolour(red, green, blue, alpha) {
    
    return `rgba(${red || this.red}, ${green || this.green}, ${blue || this.blue}, ${alpha || this.alpha})`;
    
  }
  
}
 
let updatecanvassize = () => {
  canvas.width = window.innerwidth;
  canvas.height = window.innerheight;
};
 
 
// run it!
 
updatecanvassize();
$(window).resize(updatecanvassize);
$(canvas).on('click', (e) => {
  
  createfirework(e.clientx, e.clienty);
  
  // stop fireworks when clicked, re-enable after short time
  disableautofireworks = true;
  cleartimeout(resetdisable);
  resetdisable = settimeout(() => {
    disableautofireworks = false;
  }, 5000);
  
});
 
loop();
 
</script>
 
</body>
</html>



以上就是关于“使用JS实现十类美观的页面动态效果”的相关知识,感谢各位的阅读,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注群英网络,小编每天都会为大家更新不同的知识。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

标签: JS,网页,特效
相关信息推荐
2022-10-27 18:48:17 
摘要:Trigger(窗口触发器)决定了窗口(由 WindowAssigner 产生)什么时候调用窗口处理函数。可以根据指定的时间或数据元素条件来决定什么时候触发。本文将详细讲讲其用法,需要的可以参考一下
2022-01-26 09:16:54 
摘要:用PHP怎么样实现翻译功能?对于翻译的功能相信大家都不陌生,那么我们如果是使用PHP来实现这个功能要怎样做呢?对此,下文给大家分享一个示例,文中示例代码有一定的参考学习价值,需要的朋友可以参考了解看看。
2022-02-17 18:29:40 
摘要:这篇文章给大家分享的是Linux中搭建PHP环境的方法过程。文中的教程介绍得很详细,不了解如何进行PHP环境配置的朋友可以参考,接下来就跟随小编一起了解看看吧。
云活动
推荐内容
热门关键词
热门信息
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部