zoukankan      html  css  js  c++  java
  • css3桃花随意飘落

    桃花随意飘落

    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>
    View Code
  • 相关阅读:
    【洛谷P5305】旧词
    【洛谷P5470】序列
    【CF865D】Buy Low Sell High
    【洛谷P3242】接水果
    【洛谷P5048】Yuno loves sqrt technology III
    一、Java语言基础(1)_走进java——JDK-JRE-JVM概述
    一、Java语言基础(1)_走进java——跨平台/可移植性
    第一阶段:前端开发_JavaScript基础
    第一阶段:前端开发_HTML表单&CSS
    第一阶段:前端开发_HTML&CSS
  • 原文地址:https://www.cnblogs.com/dshvv/p/14641302.html
Copyright © 2011-2022 走看看