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
  • 相关阅读:
    Atitit sumdoc everything index tech and index log 目录 1. 使用的tech 1 1.1. Atitit 日志记录的三个trace跟踪等级文件夹级
    Atitit nlp用到的技术与常见类库 目录 1. 常用的技术 1 1.1. 语言处理基础技术 分词 相似度等 1 1.2. 新闻摘要 2 1.3. 情感倾向分析 2 1.4. 文章标签 2 1.
    Atitit 资源类型的分类法规范MIME类型类型 目录 1.1. 一个MIME类型至少包括两个部分:一个类型(type)和一个子类型(subtype)。 1 1.2. 命名格式MIME类型包括一个
    Atitit 六种知识表示法 目录 1. 知识的静态描述和动态描述 1 1.状态空间表示 以状态和运算符(operator) 1 2.问题归约表示(函数式?? 1 (1)一个初始问题描述; 2 (2)
    微信小程序登录流程总结 目录 1.1. 前端调用wx.login 。。给后端传递一个code 1 1.2. 开发者需要在开发者服务器后台调用 auth.code2Session,使用 code 换取
    Atititi 计算机系 教材 目录 1. 硬件类 2 1.1. 《微机系统与接口技术》 2 1.2. 《计算机组成与系统结构(第2版)》 2 2. Atitit 操作系统原理 操作系统原理(cpu
    Atitit 声音和音乐检索 多媒体信息检索 信息检索 目录 1.1. 14.4.5 音频基础知识 1 1.2. 多媒体信息检索的方法主要有哪些?其原理是什么? 1 1.3. 基于文本的检索和基于
    Atitit 信息检索 v3 t55.docx Atitit 现代信息检索 目录 1.1. 信息检索(索引 索引 结构化文本 1 1.2. Atitit 重要章节 1 1.3. 息检索建模 1 1.
    Atiitt 程序语言vm与rt 虚拟机与运行时 目录 1. 运行时 虚拟机的一种,一般指进程级别的虚拟机。 1 1.1. 线程模型 1 1.2. 堆栈机vs 寄存器 1 1.3. 存储模型 2 1
    Atiitt 图像处理的常见功能业务用途与类库与功能实现 目录 1. 常见业务场景 3 1.1. 缩略图 蒙版遮罩挖空 3 1.2. 区域裁剪,水印,旋转 3 1.3. 判断图像大小分辨率要求
  • 原文地址:https://www.cnblogs.com/dshvv/p/14641302.html
Copyright © 2011-2022 走看看