桃花随意飘落
css3 + js
不实用第三方类库
效果图
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <script> //生成从minNum到maxNum的随机数 const randomNum = (minNum, maxNum) => { if (minNum && maxNum) { return parseInt(Math.random() * (maxNum - minNum + 1) + minNum, 10); } else if (minNum) { return parseInt(Math.random() * minNum + 1, 10); } else { return parseInt(Math.random() * 10, 10); } } // 桃花素材 const snowflakeURl = new Array(8).fill().map((item, index) => `./images/icon_petal_${index + 1}.png`) // 随机六张图 const getImagesName = () => snowflakeURl[randomNum(8)]; // 创建一个雪花元素 const createSnow = () => { const startPositionLeft = randomNum(document.body.offsetWidth); let randomStart = Math.random(); randomStart = randomStart < 0.5 ? 1 : randomStart; const snowboxCssText = ` position: fixed; top:-10px; 25px; transform: rotate(0deg); height: 26px; background-repeat:no-repeat; opacity:${randomStart}; background-image: url(${getImagesName()}); left:${startPositionLeft}px; `; const snow = document.createElement('div'); snow.style.cssText = snowboxCssText; return snow; } const main = () => { // 造新落花 const snow = createSnow(); document.body.appendChild(snow); const duration = randomNum(6, 10) * 1000; //随机下落时间 const endPositionLeft = Number(snow.style.left.replace('px', '')) - 100 + Math.random() * 500 + 'px'; //所及下落左/右位置 snow.animate([ { top: 1000 + 'px', transform: `rotate(${randomNum(100, 360 * 3)}deg)`, left: endPositionLeft } ], { duration }) snow.getAnimations().map((animation) => { animation?.finished.then(() => { console.log('finished'); snow.remove(); }) }) } main() setInterval(async () => { main() }, 300) </script> </body> </html>
图片资源下载
以下是我转成base64图片的代码,不需要图片资源
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <script> const base64Img = [ '', '', '', '', '', '', '', '' ]; //生成从minNum到maxNum的随机数 const randomNum = (minNum, maxNum) => { if (minNum && maxNum) { return parseInt(Math.random() * (maxNum - minNum + 1) + minNum, 10); } else if (minNum) { return parseInt(Math.random() * minNum + 1, 10); } else { return parseInt(Math.random() * 10, 10); } } // 桃花素材 const snowflakeURl = new Array(8).fill().map((item, index) => `./images/icon_petal_${index + 1}.png`) // 随机六张图 // const getImagesName = () => snowflakeURl[randomNum(8)]; const getImagesName = () => base64Img[randomNum(8)]; // 创建一个雪花元素 const createSnow = () => { const startPositionLeft = randomNum(document.body.offsetWidth); let randomStart = Math.random(); randomStart = randomStart < 0.5 ? 1 : randomStart; const snowboxCssText = ` position: fixed; top:-10px; 25px; transform: rotate(0deg); height: 26px; background-repeat:no-repeat; opacity:${randomStart}; background-image: url(${getImagesName()}); left:${startPositionLeft}px; `; const snow = document.createElement('div'); snow.style.cssText = snowboxCssText; return snow; } const main = () => { // 造新落花 const snow = createSnow(); document.body.appendChild(snow); const duration = randomNum(6, 10) * 1000; //随机下落时间 const endPositionLeft = Number(snow.style.left.replace('px', '')) - 100 + Math.random() * 500 + 'px'; //所及下落左/右位置 snow.animate([ { top: 1000 + 'px', transform: `rotate(${randomNum(100, 360 * 3)}deg)`, left: endPositionLeft } ], { duration }) snow.getAnimations().map((animation) => { animation?.finished.then(() => { console.log('finished'); snow.remove(); }) }) } main() setInterval(async () => { main() }, 300) </script> </body> </html>