js+css实现红包雨效果

本文实例为大家分享了js实现红包雨展示的具体代码,供大家参考,具体内容如下

1.html部分

红包的样子,先写一个模版在页面

rush:xhtml;">

显示红包的容器

rush:xhtml;">

2.js部分

//每一个红包都是相对于父元素定位,通过z-index来设置层级
let zIndex = 1;

function bindEvent() {
$redPackage.on('click','.js-RedPackageBox',function() {
//拿到每个红包的数据
const data = $(this).data('txt');
}
}

//生成mix-max的随机数
function getRandom(min,max) {
return Math.round(Math.random() * (max - min) + min);
}

//红包的移动
function redPackageBoxSpeed($el,time) {
$el.animate(
{
top: '130%',},time * 1000,function() {
$el.remove();
}
);
}

//生成红包
function createRedPackageNode() {
const $newNode = $redPackageBox.clone(true);
//红包携带的数据
const txt = keyList.shift();
keyList.push(txt);
$newNode.attr('data-txt',JSON.stringify(txt));

//红包随机旋转-30~30度
$newNode.css({
'z-index': zIndex++,left: getRandom(basePadding,maxLeftPx) + 'px',transform: 'rotate(' + getRandom(-30,30) + 'deg)',});
$redPackage.append($newNode);

redPackageBoxSpeed($newNode,4);
}

//红包的动态创建
function createRedPackageRain() {
setInterval(() => {
createRedPackageNode();
},300);
}

function ready() {
bindEvent();
createRedPackageRain();
}

ready();

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

什么是深拷贝与浅拷贝?深拷贝与浅拷贝是js中处理对象或数据...
前言 今天复习了一些前端算法题,写到一两道比较有意思的题:...
最近在看回JavaScript的面试题,this 指向问题是入坑前端必须...
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面