十个拿来就能用的网页炫酷特效

编程之家收集整理的这篇文章主要介绍了十个拿来就能用的网页炫酷特效编程之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

-------------写在前面-------------

之前喜欢收集能美化网页代码,比如给网页加个背景啦,给鼠标加个特效啦,来来回回也收集到了一些“使用简单”,“效果爆炸”的页面,给大家陆续分享出来,如果觉得有帮助可以点赞收藏支持一下,如果能关注一下就再好不过了ヾ(≧▽≦*)o,之后还会分享许多干货,话不多说,先看组合好的效果

目录

1、鼠标点击弹出爱心

@L_403_1@

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

4、鼠标小星星拖尾跟随

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

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

7、樱花特效

8、蜘蛛网特效

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

10、烟花


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.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,0)";
    ctx.clearRect(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,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,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,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.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,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,};
        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,randomcolor(colors)
            )
          );
        }
      }

      // Animation Loop
      function animate() {
        requestAnimationFrame(animate);
        c.fillStyle = "rgba(255,0.05)";
        c.fillRect(0,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,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,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,{
						x: randomFnx,y: randomFny,r: randomFnR
					});
					sakura.draw(cxt);
					sakuraList.push(sakura);
				}
				stop = requestAnimationFrame(function() {
					cxt.clearRect(0,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"),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,a,c);
        var n,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,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,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,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,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,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,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>

解锁查看全部内容

付费后查看完整内容
限时 微信扫码支付 ¥9.9 19.9

总结

以上是编程之家为你收集整理的十个拿来就能用的网页炫酷特效全部内容,希望文章能够帮你解决十个拿来就能用的网页炫酷特效所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

JavaScript相关文章

将npm升级到最新版本即可【】npm WARN config global `--global`, `--local` are deprecated. Use `--location=global` instead.
其实从填写上url按下回车后,我们就进入了第一步就是 DNS 解析过程,首先需要找到这个 url 域名的服务器 ip,为了寻找这个 ip,浏览器首先会寻找缓存,查看缓存中是否有记录缓存中没有则查找系统的 hosts 文件中是否有记录,如果没有缓存则查询 DNS 服务器,得到服务器的 ip 地址后,浏览器根据这个 ip 以及相应的端口号发送连接请求;当然如果DNS服务器中没有解析成功,他会向上一步获得的顶级DNS服务器发送解析请求。客户端和服务端都需要直到各自可收发,因此需要三次握手。............
没想到项目放到线上后,随着请求量的增多,却感觉到首屏速度越来越慢,并且是在持续性地变慢。而且在发布完后(也就是容器重建了),耗时又陡然降下来了。因此很合理地怀疑是内存泄漏了。故而在 STKE 的监控面板瞧一瞧,内存确实是一波一波似浪花。知道是内存泄漏,我们就需要找到泄漏的点。因为不能轻易操作线上环境,线上代码也是压缩的,因此我们需要先搭建本地环境看能否方便调试问题。这里我们我们可以在本地起 Server 后,写脚本发起请求,来模拟线上环境。(但是看过上篇文章的小伙伴都知道,我们还有个骨架屏的模式,可以跳过发
文章目录数组数组声明at()push、pop、shift、unshift栈队列遍历length.length的意义.length可写Array()多维数组toString()数组比较数组的本质错误的数组使用性能总结数组前面讲到的对象虽然是非常强大的工具,但是,我们在编写代码时常常需要处理一些有序数据的集合。在有序集合中,元素的排列是有前后顺序的,例如:文章的列表、章节目录。由于对象并不能提供属性的有序访问,这种情况下,就需要我们使用新的数据结构数组。数组声明我们可以通过两种方式创建一个空的数组:.
之前喜欢收集能美化网页的代码,比如给网页加个背景啦,给鼠标加个特效啦,来来回回也收集到了一些“使用简单”,“效果爆炸”的页面,给大家陆续分享出来,如果觉得有帮助可以点赞收藏支持一下,如果能关注一下就再好不过了ヾ(≧▽≦*)o
本网站包含图标库、矢量插画库、3D插画库以及Lottie库,内容丰富且精美,只有你想不到的,没有你找不到的。拿这些精美图标来设计网页页面,一定会惊艳别人。✨美叶  .
微信公众号搜索 “ 程序精选 ” ,选择关注!
微信公众号搜 "程序精选"关注