iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >使用HTML怎么实现一个代码雨效果
  • 329
分享到

使用HTML怎么实现一个代码雨效果

2023-06-09 12:06:58 329人浏览 泡泡鱼
摘要

本篇文章为大家展示了使用html怎么实现一个代码雨效果,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。绿色:彩色:背景色:绿色逐渐变浅:源代码:<!DOCTYPE html>&l

本篇文章为大家展示了使用html怎么实现一个代码雨效果,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

绿色:

使用HTML怎么实现一个代码雨效果

彩色:

使用HTML怎么实现一个代码雨效果

背景色:

使用HTML怎么实现一个代码雨效果

绿色逐渐变浅:

使用HTML怎么实现一个代码雨效果

源代码:

<!DOCTYPE html><html>   <head>       <meta Http-equiv="Content-Type" content="text/html;charset=utf-8">    <title>Code -by ZhenYu.Sha</title>    <style type="text/CSS">        html, body {            width: 100%;            height: 100%;        }        body {            background: #000;            overflow: hidden;            margin: 0;            padding: 0;        }    </style></head>   <body>  <canvas id="cvs"></canvas><script type="text/javascript">    var cvs = document.getElementById("cvs");    var ctx = cvs.getContext("2d");    var cw = cvs.width = document.body.clientWidth;    var ch = cvs.height = document.body.clientHeight;    //动画绘制对象    var requestAnimationFrame = window.requestAnimationFrame || window.mozRequestAnimationFrame || window.WEBkitRequestAnimationFrame || window.msRequestAnimationFrame;    var codeRainArr = []; //代码雨数组    var cols = parseInt(cw / 14); //代码雨列数    var step = 16;    //步长,每一列内部数字之间的上下间隔    ctx.font = "bold 26px microsoft yahei"; //声明字体,个人喜欢微软雅黑     function createColorCv() {        //画布基本颜色        ctx.fillStyle = "#242424";        ctx.fillRect(0, 0, cw, ch);    }     //创建代码雨    function createCodeRain() {        for (var n = 0; n < cols; n++) {            var col = [];            //基础位置,为了列与列之间产生错位            var basePos = parseInt(Math.random() * 300);            //随机速度 3~13之间            var speed = parseInt(Math.random() * 10) + 3;            //每组的x轴位置随机产生            var colx = parseInt(Math.random() * cw)             //绿色随机            var rgbr = 0;            var rgbg = parseInt(Math.random() * 255);            var rgbb = 0;            //ctx.fillStyle = "rgb("+r+','+g+','+b+")"             for (var i = 0; i < parseInt(ch / step) / 2; i++) {                var code = {                    x: colx,                    y: -(step * i) - basePos,                    speed: speed,                    //  text : parseInt(Math.random()*10)%2 == 0 ? 0 : 1  //随机生成0或者1                    text: ["a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "s", "t", "u", "v", "w", "x", "y", "z"][parseInt(Math.random() * 11)], //随机生成字母数组中的一个                    color: "rgb(" + rgbr + ',' + rgbg + ',' + rgbb + ")"                }                col.push(code);            }            codeRainArr.push(col);        }    }     //代码雨下起来    function codeRaining() {        //把画布擦干净        ctx.clearRect(0, 0, cw, ch);        //创建有颜色的画布        //createColorCv();        for (var n = 0; n < codeRainArr.length; n++) {            //取出列            col = codeRainArr[n];            //遍历列,画出该列的代码            for (var i = 0; i < col.length; i++) {                var code = col[i];                if (code.y > ch) {                    //如果超出下边界则重置到顶部                    code.y = 0;                } else {                    //匀速降落                    code.y += code.speed;                }                                //1 颜色也随机变化                //ctx.fillStyle = "hsl("+(parseInt(Math.random()*359)+1)+",30%,"+(50-i*2)+"%)";                  //2 绿色逐渐变浅                // ctx.fillStyle = "hsl(123,80%,"+(30-i*2)+"%)";                  //3 绿色随机                // var r= 0;                // var g= parseInt(Math.random()*255) + 3;                // var b= 0;                // ctx.fillStyle = "rgb("+r+','+g+','+b+")";                 //4 一致绿                ctx.fillStyle = code.color;                  //把代码画出来                ctx.fillText(code.text, code.x, code.y);            }        }        requestAnimationFrame(codeRaining);    }     //创建代码雨    createCodeRain();    //开始下雨吧 Go>>    requestAnimationFrame(codeRaining);</script>   </body></html>

更多代码雨的文章请参考我的其它文章:

“代码雨”js+css+html实现

HTML代码:

<!DOCTYPE html><html><head><meta charset="utf-8"><link rel="stylesheet" type="text/css" href="css/ok.css"><title>code by-zhenyu.sha</title></head> <body><canvas id="canvas"></canvas></body><script src="http://www.jq22.com/Jquery/jquery-1.10.2.js"></script><script src="http://neilcarpenter.com/demos/canvas/matrix/stats.min.js"></script><script type="text/javascript" src="js/ok.js"></script></html>

js代码:

(function() {  var lastTime = 0;  var vendors = ['ms', 'moz', 'webkit', 'o'];  for (var x = 0; x < vendors.length && !window.requestAnimationFrame; ++x) {    window.requestAnimationFrame = window[vendors[x] + 'RequestAnimationFrame'];    window.cancelAnimationFrame = window[vendors[x] + 'CancelAnimationFrame'] ||      window[vendors[x] + 'CancelRequestAnimationFrame'];  }  if (!window.requestAnimationFrame)    window.requestAnimationFrame = function(callback, element) {      var currTime = new Date().getTime();      var timeToCall = Math.max(0, 16 - (currTime - lastTime));      var id = window.setTimeout(function() {          callback(currTime + timeToCall);        },        timeToCall);      lastTime = currTime + timeToCall;      return id;    };  if (!window.cancelAnimationFrame)    window.cancelAnimationFrame = function(id) {      clearTimeout(id);    };}());// statsvar stats = new Stats();stats.setMode(0);stats.domElement.style.position = 'absolute';stats.domElement.style.left = '0px';stats.domElement.style.top = '0px';document.body.appendChild(stats.domElement);var M = {  settings: {    COL_WIDTH: 20,    COL_HEIGHT: 25,    VELOCITY_PARAMS: {      min: 4,      max: 8    },    CODE_LENGTH_PARAMS: {      min: 20,      max: 40    }  },  animation: null,  c: null,  ctx: null,  lineC: null,  ctx2: null,  WIDTH: window.innerWidth,  HEIGHT: window.innerHeight,  COLUMNS: null,  canvii: [],  font: '30px matrix-code',  letters: ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '$', '+', '-', '*', '/', '=', '%', '"', '\'', '#', '&', '_', '(', ')', ',', '.', ';', ':', '?', '!', '\\', '|', '{', '}', '<', '>', '[', ']', '^', '~'],  codes: [],  createCodeLoop: null,  codesCounter: 0,  init: function() {    M.c = document.getElementById('canvas');    M.ctx = M.c.getContext('2d');    M.c.width = M.WIDTH;    M.c.height = M.HEIGHT;    M.ctx.shadowBlur = 0;    M.ctx.fillStyle = '#000';    M.ctx.fillRect(0, 0, M.WIDTH, M.HEIGHT);    M.ctx.font = M.font;    M.COLUMNS = Math.ceil(M.WIDTH / M.settings.COL_WIDTH);    for (var i = 0; i < M.COLUMNS; i++) {      M.codes[i] = [];      M.codes[i][0] = {        'open': true,        'position': {          'x': 0,          'y': 0        },        'strength': 0      };    }    M.loop();    M.createLines();    M.createCode();    // not doing this, kills CPU    // M.swapCharacters();    window.onresize = function() {      window.cancelAnimationFrame(M.animation);      M.animation = null;      M.ctx.clearRect(0, 0, M.WIDTH, M.HEIGHT);      M.codesCounter = 0;      M.ctx2.clearRect(0, 0, M.WIDTH, M.HEIGHT);      M.WIDTH = window.innerWidth;      M.HEIGHT = window.innerHeight;      M.init();    };  },  loop: function() {    M.animation = requestAnimationFrame(function() {      M.loop();    });    M.draw();    stats.update();  },  draw: function() {    var velocity, height, x, y, c, ctx;    // slow fade BG colour    M.ctx.shadowColor = 'rgba(0, 0, 0, 0.5)';    M.ctx.fillStyle = 'rgba(0, 0, 0, 0.5)';    M.ctx.fillRect(0, 0, M.WIDTH, M.HEIGHT);    M.ctx.globalCompositeOperation = 'source-over';    for (var i = 0; i < M.COLUMNS; i++) {      // check member of array isn't undefined at this point      if (M.codes[i][0].canvas) {        velocity = M.codes[i][0].velocity;        height = M.codes[i][0].canvas.height;        x = M.codes[i][0].position.x;        y = M.codes[i][0].position.y - height;        c = M.codes[i][0].canvas;        ctx = c.getContext('2d');        M.ctx.drawImage(c, x, y, M.settings.COL_WIDTH, height);        if ((M.codes[i][0].position.y - height) < M.HEIGHT) {          M.codes[i][0].position.y += velocity;        } else {          M.codes[i][0].position.y = 0;        }      }    }  },  createCode: function() {    if (M.codesCounter > M.COLUMNS) {      clearTimeout(M.createCodeLoop);      return;    }    var randomInterval = M.randomFromInterval(0, 100);    var column = M.assignColumn();    if (column) {      var codeLength = M.randomFromInterval(M.settings.CODE_LENGTH_PARAMS.min, M.settings.CODE_LENGTH_PARAMS.max);      var codeVelocity = (Math.random() * (M.settings.VELOCITY_PARAMS.max - M.settings.VELOCITY_PARAMS.min)) + M.settings.VELOCITY_PARAMS.min;      var lettersLength = M.letters.length;      M.codes[column][0].position = {        'x': (column * M.settings.COL_WIDTH),        'y': 0      };      M.codes[column][0].velocity = codeVelocity;      M.codes[column][0].strength = M.codes[column][0].velocity / M.settings.VELOCITY_PARAMS.max;      for (var i = 1; i <= codeLength; i++) {        var newLetter = M.randomFromInterval(0, (lettersLength - 1));        M.codes[column][i] = M.letters[newLetter];      }      M.createCanvii(column);      M.codesCounter++;    }    M.createCodeLoop = setTimeout(M.createCode, randomInterval);  },  createCanvii: function(i) {    var codeLen = M.codes[i].length - 1;    var canvHeight = codeLen * M.settings.COL_HEIGHT;    var velocity = M.codes[i][0].velocity;    var strength = M.codes[i][0].strength;    var text, fadeStrength;    var newCanv = document.createElement('canvas');    var newCtx = newCanv.getContext('2d');    newCanv.width = M.settings.COL_WIDTH;    newCanv.height = canvHeight;    for (var j = 1; j < codeLen; j++) {      text = M.codes[i][j];      newCtx.globalCompositeOperation = 'source-over';      newCtx.font = '30px matrix-code';      if (j < 5) {        newCtx.shadowColor = 'hsl(104, 79%, 74%)';        newCtx.shadowOffsetX = 0;        newCtx.shadowOffsetY = 0;        newCtx.shadowBlur = 10;        newCtx.fillStyle = 'hsla(104, 79%, ' + (100 - (j * 5)) + '%, ' + strength + ')';      } else if (j > (codeLen - 4)) {        fadeStrength = j / codeLen;        fadeStrength = 1 - fadeStrength;        newCtx.shadowOffsetX = 0;        newCtx.shadowOffsetY = 0;        newCtx.shadowBlur = 0;        newCtx.fillStyle = 'hsla(104, 79%, 74%, ' + (fadeStrength + 0.3) + ')';      } else {        newCtx.shadowOffsetX = 0;        newCtx.shadowOffsetY = 0;        newCtx.shadowBlur = 0;        newCtx.fillStyle = 'hsla(104, 79%, 74%, ' + strength + ')';      }      newCtx.fillText(text, 0, (canvHeight - (j * M.settings.COL_HEIGHT)));    }    M.codes[i][0].canvas = newCanv;  },  swapCharacters: function() {    var randomCodeIndex;    var randomCode;    var randomCodeLen;    var randomCharIndex;    var newRandomCharIndex;    var newRandomChar;    for (var i = 0; i < 20; i++) {      randomCodeIndex = M.randomFromInterval(0, (M.codes.length - 1));      randomCode = M.codes[randomCodeIndex];      randomCodeLen = randomCode.length;      randomCharIndex = M.randomFromInterval(2, (randomCodeLen - 1));      newRandomCharIndex = M.randomFromInterval(0, (M.letters.length - 1));      newRandomChar = M.letters[newRandomCharIndex];      randomCode[randomCharIndex] = newRandomChar;    }    M.swapCharacters();  },  createLines: function() {    M.linesC = document.createElement('canvas');    M.linesC.width = M.WIDTH;    M.linesC.height = M.HEIGHT;    M.linesC.style.position = 'absolute';    M.linesC.style.top = 0;    M.linesC.style.left = 0;    M.linesC.style.zIndex = 10;    document.body.appendChild(M.linesC);    var linesYBlack = 0;    var linesYWhite = 0;    M.ctx2 = M.linesC.getContext('2d');    M.ctx2.beginPath();    M.ctx2.lineWidth = 1;    M.ctx2.strokeStyle = 'rgba(0, 0, 0, 0.7)';    while (linesYBlack < M.HEIGHT) {      M.ctx2.moveTo(0, linesYBlack);      M.ctx2.lineTo(M.WIDTH, linesYBlack);      linesYBlack += 5;    }    M.ctx2.lineWidth = 0.15;    M.ctx2.strokeStyle = 'rgba(255, 255, 255, 0.7)';    while (linesYWhite < M.HEIGHT) {      M.ctx2.moveTo(0, linesYWhite + 1);      M.ctx2.lineTo(M.WIDTH, linesYWhite + 1);      linesYWhite += 5;    }    M.ctx2.stroke();  },  assignColumn: function() {    var randomColumn = M.randomFromInterval(0, (M.COLUMNS - 1));    if (M.codes[randomColumn][0].open) {      M.codes[randomColumn][0].open = false;    } else {      return false;    }    return randomColumn;  },  randomFromInterval: function(from, to) {    return Math.floor(Math.random() * (to - from + 1) + from);  },  snapshot: function() {    window.open(M.c.toDataURL());  }};function eventListenerz() {  var controlToggles = document.getElementsByClassName('toggle-info');  var controls = document.getElementById('info');  var snapshotBtn = document.getElementById('snapshot');  function toggleControls(e) {    e.preventDefault();    controls.className = controls.className === 'closed' ? '' : 'closed';  }  for (var j = 0; j < 2; j++) {    controlToggles[j].addEventListener('click', toggleControls, false);  }  snapshotBtn.addEventListener('click', M.snapshot, false);}window.onload = function() {  M.init();  eventListenerz();};

css代码:

@import url("http://fonts.googleapis.com/css?family=Carrois+Gothic");@font-face {  font-family: 'matrix-code';  src: url('http://neilcarpenter.com/demos/canvas/matrix/font/matrix-code.eot?#iefix') fORMat('embedded-opentype'), url('http://neilcarpenter.com/demos/canvas/matrix/font/matrix-code.woff') format('woff'), url('http://neilcarpenter.com/demos/canvas/matrix/font/matrix-code.ttf') format('truetype'), url('http://neilcarpenter.com/demos/canvas/matrix/font/matrix-code.svg#svgFontName') format('svg');}html,body {  -webkit-font-smoothing: antialiased;  font: normal 12px/14px "Carrois Gothic", sans-serif;  width: 100%;  height: 100%;  margin: 0;  overflow: hidden;  color: #fff;  -webkit-user-select: none;  -moz-user-select: none;  -ms-user-select: none;  user-select: none;}body {  background: black;}#stats {  z-index: 100;}#info {  background: rgba(0, 0, 0, 0.7);  position: fixed;  bottom: 0;  left: 0px;  width: 250px;  padding: 10px 20px 20px;  z-index: 100;  -webkit-transform-origin: bottom center;  -moz-transform-origin: bottom center;  -o-transform-origin: bottom center;  transform-origin: bottom center;  -webkit-transform: rotate(0deg);  -moz-transform: rotate(0deg);  -o-transform: rotate(0deg);  transform: rotate(0deg);  -webkit-transition: -webkit-transform .5s ease-in-out;  -moz-transition: -moz-transform .5s ease-in-out;  -o-transition: -o-transform .5s ease-in-out;  transition: transform .5s ease-in-out;}#info.closed {  -webkit-transform: rotate(180deg);  -moz-transform: rotate(180deg);  -o-transform: rotate(180deg);  transform: rotate(180deg);}.toggle-info {  position: absolute;  display: block;  height: 10px;  background: rgba(0, 0, 0, 0.8);  width: 290px;  left: 0;  text-align: center;  padding: 3px 0 7px;  text-decoration: none;  color: white;  text-shadow: none;}.toggle-info:hover {  background: rgb(0, 0, 0);}#close {  top: -20px;}#open {  bottom: -20px;  -webkit-transform: rotate(-180deg);  -moz-transform: rotate(-180deg);  -o-transform: rotate(-180deg);  transform: rotate(-180deg);}button {  background: rgba(255, 255, 255, 0.2);  color: #fff;  border: 0;  border-radius: 2px;  padding: 7px 10px;  box-shadow: 0 0 3px 0px rgba(255, 255, 255, 0.3);  cursor: pointer;}button:hover {  background: rgba(255, 255, 255, 0.1);}pa {  color: #fff;}pa:hover {  color: #EFFDEB;  text-shadow: 0px 0px 5px #75AD61;}

上述内容就是使用HTML怎么实现一个代码雨效果,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网精选频道。

--结束END--

本文标题: 使用HTML怎么实现一个代码雨效果

本文链接: https://www.lsjlt.com/news/255821.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 使用HTML怎么实现一个代码雨效果
    本篇文章为大家展示了使用HTML怎么实现一个代码雨效果,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。绿色:彩色:背景色:绿色逐渐变浅:源代码:<!DOCTYPE html>&l...
    99+
    2023-06-09
  • 使用canvas怎么实现一个数字雨效果
    使用canvas怎么实现一个数字雨效果?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。效果图:代码:<!DOCTYPE html><h...
    99+
    2023-06-09
  • JavaScript实现代码雨效果
    本文实例为大家分享了JavaScript实现代码雨效果的具体代码,供大家参考,具体内容如下 <!DOCTYPE html> <html lang="en"> ...
    99+
    2024-04-02
  • js+canvas实现代码雨效果
    本文实例为大家分享了js+canvas代码雨效果的具体代码,供大家参考,具体内容如下 代码: <!DOCTYPE html> <html> <h...
    99+
    2024-04-02
  • JavaScript canvas实现代码雨效果
    本文实例为大家分享了canvas实现代码雨效果的具体代码,供大家参考,具体内容如下 先看效果图 这个效果图是不是像极了以前电影里面的黑客技术,看起来蛮难的,其实操作起来还是挺简单的...
    99+
    2024-04-02
  • 使用canvas怎么实现一个下雨效果的示例
    本篇文章为大家展示了使用canvas怎么实现一个下雨效果的示例,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。<!doctype html><html lang=...
    99+
    2023-06-09
  • 怎么用html实现流星雨的效果
    小编给大家分享一下怎么用html实现流星雨的效果,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!   <!doctypeh...
    99+
    2024-04-02
  • C语言实现代码雨效果
    本文实例为大家分享了C语言实现代码雨效果的具体代码,供大家参考,具体内容如下 一、项目描述和最终的效果展示 项目:   让字符从上到下依次的下落,呈现出代码雨。 最终效果图...
    99+
    2024-04-02
  • html流星雨代码怎么实现
    本教程操作环境:Windows10系统、HTML5版本、Dell G3电脑。html流星雨代码怎么实现?动态流星雨制作代码分享(可直接复制)流星雨制作效果图(流星带颜色的,截图没显示):今天在书上,看到了一个不错的流星雨制作案例,感觉挺好看...
    99+
    2023-05-14
    html
  • Python+Pygame实现代码雨动画效果
    pygame实现代码雨动画 如视频所示 利用pygame库实现了一个代码呈雨状下落的视觉效果 部分代码如下 import sys import random import py...
    99+
    2024-04-02
  • Python实现屏幕代码雨效果的示例代码
    直接上代码 import pygame import random def main(): # 初始化pygame pygame.init() #...
    99+
    2024-04-02
  • Python实现新年愿望代码雨效果
    目录1、引言2、代码实战2.1 模块介绍2.2 代码示例3、总结1、引言 小丝:鱼哥,2023年了, 你有啥愿望啊? 小鱼:这, 我可以选择不告诉你吗? 小丝:可以选择不告诉我,但是...
    99+
    2023-01-12
    Python新年愿望代码雨 Python新年代码雨 Python代码雨
  • 使用html怎么实现一个滚动歌词效果
    使用html怎么实现一个滚动歌词效果?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。html是什么html的全称为超文本标记语言,它是一种标记语言,包含了一系列标签.通过这些标签...
    99+
    2023-06-06
  • Python如何实现代码雨动画效果
    本篇内容介绍了“Python如何实现代码雨动画效果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!代码如下import sysimp...
    99+
    2023-07-04
  • JavaScript中canvas实现代码雨效果的方法
    这篇文章将为大家详细讲解有关JavaScript中canvas实现代码雨效果的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。本文实例为大家分享了canvas实现代码雨效果的具体代码,供大家参考,具体内...
    99+
    2023-06-15
  • jquery插件怎么实现代码雨特效
    这篇文章将为大家详细讲解有关jquery插件怎么实现代码雨特效,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。jquery是什么jquery是一个简洁而快速的JavaScript库,它具有独特的链式语法和短...
    99+
    2023-06-14
  • JavaScript实现流星雨效果的示例代码
    目录演示技术栈源码首先建立星星对象让星星闪亮起来创建流星雨对象让流星动起来演示 上一次做了一个雨滴的动画,顺着这种思维正好可以改成流星雨,嘿嘿我真是一个小机灵。 技术栈 还是先建立...
    99+
    2024-04-02
  • 怎么使用纯CSS代码实现一个沙漏的动画效果
    这篇文章主要为大家展示了“怎么使用纯CSS代码实现一个沙漏的动画效果”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么使用纯CSS代码实现一个沙漏的动画效果”这...
    99+
    2024-04-02
  • 怎么使用JavaScript canvas实现字符雨效果
    本文小编为大家详细介绍“怎么使用JavaScript canvas实现字符雨效果”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么使用JavaScript canvas实现字符雨效果”文章能帮助大家解决疑惑,下面跟着小...
    99+
    2023-07-02
  • 如何用JS实现代码雨特效
    这篇“如何用JS实现代码雨特效”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“如何用JS实现代码雨特效”文章吧。html代码&...
    99+
    2023-06-26
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作