这篇文章主要介绍js+css如何实现红包雨效果,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

创新互联公司是一家专业提供
江北企业网站建设,专注与做网站、
成都网站制作、
成都h5网站建设、小程序制作等业务。10年已为江北众多企业、政府机构等服务。创新互联专业网站制作公司优惠进行中。
具体内容如下
1.html部分
红包的样子,先写一个模版在页面上
显示红包的容器
2.js部分
const $redPackage = $('.js-RedPackage');
const $redPackageBox = $('.js-RedPackageBox');
const redPackageWidth = $redPackage.width();
const redPackageBoxWidth = $redPackageBox.width();
//因为红包有角度旋转的问题,所以需要计算一下,避免旋转之后溢出屏幕
const basePadding = 30;
const maxLeftPx = redPackageWidth - redPackageBoxWidth - basePadding * 2;
//每一个红包都是相对于父元素定位,通过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+css如何实现红包雨效果”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!
网页名称:js+css如何实现红包雨效果-创新互联
分享链接:
http://jxjierui.cn/article/ccjooj.html