JavaScript实现代码雨

一、功能描述

使用canvas实现一个代码雨的功能,炫一个~~~

二、上码

html

html 复制代码
 <canvas id="canvas"></canvas>

js

javascript 复制代码
        let canvas = document.querySelector('canvas');
        let ctx = canvas.getContext('2d');
        // screen.availWidth:可视区域的宽度
        canvas.width = screen.availWidth;
        canvas.height = screen.availHeight;

        let str = 'zyk01010168'.split('');
        const px = 10;
        let arr = Array(Math.ceil(canvas.width / px )).fill(0)
        const rain = () => {
            //使用,0.05模糊,每次都重叠绘制。看出虚幻的效果
            ctx.fillStyle = 'rgba(0,0,0,0.05)';
            ctx.fillRect(0, 0, canvas.width, canvas.height);
            ctx.fillStyle = '#00FF00';
            arr = arr.map((ele,index) => {
                //横向间隔px的距离显示字母
                ctx.fillText(str[Math.floor(Math.random() * str.length)], index * px, ele + px);
                //修改纵向坐标
                return (ele > canvas.height || ele > 5000 * Math.random()) ? 0 : ele+ 10
            });
        }
        setInterval(rain, 40)
相关推荐
C_心欲无痕12 小时前
前端实现水印的两种方式:SVG 与 Canvas
前端·安全·水印
尾善爱看海15 小时前
不常用的浏览器 API —— Web Speech
前端
美酒没故事°15 小时前
vue3拖拽+粘贴的综合上传器
前端·javascript·typescript
jingling55516 小时前
css进阶 | 实现罐子中的水流搅拌效果
前端·css
悟能不能悟18 小时前
前端上载文件时,上载多个文件,但是一个一个调用接口,怎么实现
前端
可问春风_ren18 小时前
前端文件上传详细解析
前端·ecmascript·reactjs·js
羊小猪~~19 小时前
【QT】--文件操作
前端·数据库·c++·后端·qt·qt6.3
晚风资源组20 小时前
CSS文字和图片在容器内垂直居中的简单方法
前端·css·css3
Miketutu21 小时前
Flutter学习 - 组件通信与网络请求Dio
开发语言·前端·javascript
摘星编程21 小时前
React Native for OpenHarmony 实战:Swiper 滑动组件详解
javascript·react native·react.js