js+css实现红包雨效果
更新时间:2018年07月12日 08:41:15 作者:简若澈
这篇文章主要为大家详细介绍了js+css实现红包雨效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了js实现红包雨展示的具体代码,供大家参考,具体内容如下
1.html部分
红包的样子,先写一个模版在页面上
<div class="hide"> <div class="RedPackage__Box js-RedPackageBox" data-txt> <img src="./images/redPackage.png" alt=""> </div> </div>
显示红包的容器
<div class="RedPackage__Main js-RedPackage"></div>
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();
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
关于bootstrap日期转化,bootstrap-editable的简单使用,bootstrap-fileinput的
这篇文章主要介绍了关于bootstrap日期转化,bootstrap-editable的简单使用,bootstrap-fileinput的使用,需要的朋友可以参考下2017-05-05
解决select2在bootstrap modal中不能正常使用的问题
今天小编就为大家分享一篇解决select2在bootstrap modal中不能正常使用的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-08-08
uniapp自定义tabbar的方法(支持中间凸起、角标、动态隐藏tab和全端适用)
一个项目有多个角色,比如医生和患者,tabBar跳转的路径不一样,但是在pages.json中无法配置多个tabBar,这时候就要自定义tabBar了,下面这篇文章主要给大家介绍了关于uniapp自定义tabbar(支持中间凸起、角标、动态隐藏tab和全端适用)的相关资料,需要的朋友可以参考下2023-04-04
JS获取URL中参数值(QueryString)的4种方法分享
今天碰到要在一个页面获取另外一个页面url传过来的参数,一开始很本能的想到了用 split("?")这样一步步的分解出需要的参数。后来想了一下,肯定会有更加简单的方法的!所以在网上找到了几个很又简单实用的方法,mark下。2014-04-04


最新评论