桃花随意飘落

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;
width: 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;
width: 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>

css3桃花随意飘落的更多相关文章

  1. CSS3梅花三弄特效

    效果预览:http://hovertree.com/texiao/js/22/ 效果图: 代码如下: <html> <head> <meta http-equiv=&qu ...

  2. HTML 5 +CSS3 + 原生js 做(雪花全屏飘落 + 3d旋转图)

    原文:HTML 5 +CSS3 + 原生js 做(雪花全屏飘落 + 3d旋转图) 3d旋转图:主要用css3中transform属性中的rotate,translate;以及用来做舞台效果的 pers ...

  3. @font-face(css3属性)实如今网页中嵌入随意字体

    @font-face语法规则 @font-face { font-family: <YourWebFontName>; src: <source> [<format> ...

  4. CSS3随意记录

    1.注释 注释语法:/* 注解注释内容 */ 2.带有透明度 rgba(255,0,0,0.5);rgba(0,255,0,0.5);rgba(0,0,255,0.5); 0.5就带有透明的,介于0和 ...

  5. CSS3与页面布局学习总结(七)——前端预处理技术(Less、Sass、CoffeeScript、TypeScript)

    CSS不像其它高级语言一样支持算术运算.变量.流程控制与面向对象特性,所以CSS样式较多时会引起一些问题,如修改复杂,冗余,某些别的语言很简单的功能实现不了等.而javascript则是一种半面向对象 ...

  6. CSS3动画第二式--组合动画

    接第一式之后的进阶招式,加入一些组合动画,剧情.动画啥的都是随意瞎想的,纯粹是为了熟悉2D.3D和过渡等css3代码写法.效果见下图: 代码如下(有点长,折叠一下): <!DOCTYPE htm ...

  7. CSS3属性transform详解之(旋转:rotate,缩放:scale,倾斜:skew,移动:translate)

    CSS3属性transform详解之(旋转:rotate,缩放:scale,倾斜:skew,移动:translate)   在CSS3中,可以利用transform功能来实现文字或图像的旋转.缩放.倾 ...

  8. css3媒体查询实现网站响应式布局

    最常见的办法就是基类(最常用的网站布局)+扩展类(几种不同的网站布局类)来实现不同的布局. <!–使用说明:网站基本布局,使用class="layout";使用ipad访问时 ...

  9. CSS3与页面布局学习笔记(七)——前端预处理技术(Less、Sass、CoffeeScript、TypeScript)

    CSS不像其它高级语言一样支持算术运算.变量.流程控制与面向对象特性,所以CSS样式较多时会引起一些问题,如修改复杂,冗余,某些别的语言很简单的功能实现不了等.而javascript则是一种半面向对象 ...

  10. HTML5树叶飘落动画

    查看效果:http://keleyi.com/keleyi/phtml/css3/15.htm 请使用Chrome浏览器查看本效果. html源代码: <!DOCTYPE HTML> &l ...

随机推荐

  1. 经过几天的努力Biwen.AutoClassGen终于实现了DTO复杂属性的生成

    前言 距写上一篇 https://www.cnblogs.com/vipwan/p/18535459 生成DTO已经有一段时间了, 最初没有考虑复杂二级属性嵌套的实现,而是直接使用排除使用自定义的方式 ...

  2. 云备份技术解析:云容灾 CT-CDR 关键技术介绍

    本文分享自天翼云开发者社区<云备份技术解析:云容灾 CT-CDR 关键技术介绍>,作者:沈****军 1.CDP+存储快照,实现秒级RPO (1)CDP技术:云容灾CT-CDR(Cloud ...

  3. springboot整合log4j

    一.默认名log4j2-spring.xml,就省下了在application.yml中配置 <console name="Console" target="SYS ...

  4. 剑气纵横千行码:AI写就的设计模式侠客行助您仗剑走天涯

    烟火里的江湖旧忆 暮色里,代码侠的电动车在巷口急刹,外卖箱里的热汤晃出细响,恍惚间竟像当年工厂堡锻造炉的轰鸣.难得休息之余,他抹了把额头的汗,扶了扶常开网约车的腰,摸了摸自己晒黑的脸,偶感那颠炒粉的手 ...

  5. c#实现 正弦sin、反正弦arcsin,正切tan、反正切arctan:求角度值

    1 #region 三角函数和反三角函数 2 3 using System; 4 using System.Collections.Generic; 5 using System.IO; 6 usin ...

  6. 基于Cherry Studio + DeepSeek 搭建本地私有知识库!

    在当今数字化时代,知识管理变得越来越重要.无论是个人还是企业,都希望能够高效地存储.管理和检索知识.而借助 AI 技术,我们可以实现更加智能的知识库系统.本文将详细介绍如何使用 Cherry Stud ...

  7. 3.4K star!全能PDF处理神器开源!文档转换/OCR识别一键搞定

    嗨,大家好,我是小华同学,关注我们获得"最新.最全.最优质"开源项目和高效工作学习方法 PDF-Guru 是一款开箱即用的全能型PDF处理工具,支持跨平台文档转换.智能OCR识别. ...

  8. Java编程--设计模式之装饰者模式

    目录 装饰者模式 简介 做馒头实例 生产汽车实例 常见使用 装饰者模式 简介 装饰者模式的主要功能就是对一个类的功能进行扩充! 对于需要对某个类扩充,但是该类是final类,不能被继承,这是时候可以用 ...

  9. WordPress插件:dsdiss-ai-paraphrasing(火山引擎版)文章伪原创 !一键创作!升级!

    本站原创!<文章伪原创插件(火山引擎版)>是一款基于WordPress开发的高效内容创作工具,依托火山方舟AI模型实现智能化文章伪原创处理.插件支持在后台配置API密钥与模型ID,可灵活设 ...

  10. RPC实战与核心原理之网络通信

    架构设计:涉及一个灵活的RPC框架 回顾 RPC的通信原理及RPC中各个功能组件的作用 RPC就是把拦截到的方法参数,转成可以在网络中传输的二进制,并保证服务提供方能正确还原出语义,最终实现想调用本地 ...