效果:canvas
原理:數組
用canvas逐行輸出文字,而後讓背景顏色逐漸加深,再隨機中斷某些列。dom
代碼:spa
HTML:.net
<canvas id="c"></canvas>
CSS:code
canvas {display: block;}
JS:blog
var c = document.getElementById("c"); var ctx = c.getContext("2d"); //全屏 c.height = window.innerHeight; c.width = window.innerWidth; //文字 var txts = "0123456789"; //轉爲數組 txts = txts.split(""); var font_size = 16; var columns = c.width/font_size; //用於計算輸出文字時座標,因此長度即爲列數 var drops = []; //初始值 for(var x = 0; x < columns; x++) drops[x] = 1; //輸出文字 function draw() { //讓背景逐漸由透明到不透明 ctx.fillStyle = "rgba(0, 0, 0, 0.05)"; ctx.fillRect(0, 0, c.width, c.height); ctx.fillStyle = "#0F0"; //文字顏色 ctx.font = font_size + "px arial"; //逐行輸出文字 for(var i = 0; i < drops.length; i++) { //隨機取要輸出的文字 var text = txts[Math.floor(Math.random()*txts.length)]; //輸出文字,注意座標的計算 ctx.fillText(text, i*font_size, drops[i]*font_size); //若是繪滿一屏或隨機數大於0.95(此數可自行調整,效果會不一樣) if(drops[i]*font_size > c.height || Math.random() > 0.95) drops[i] = 0; //用於Y軸座標增長 drops[i]++; } } setInterval(draw, 33);