html仿拆红包效果旋转,利⽤React加CSS3实现拆红
包动画效果实例(代码)...
本篇⽂章主要介绍了利⽤React加CSS3实现拆红包动画效果实例(代码),具有⼀定的参考价值,感兴趣的⼩伙伴们可以参考⼀下。
红包曾经引爆过⼀系列的营销热潮,相信⼤家对于这种红包形式并不陌⽣,这⾥本着娱乐⾄上的精神⽤React简单地实现了拆红包的动画效果,供⼤家⼀起交流学习
⽤CSS3绘制红包.redpack {
height: 450px;
background: #A5423A;
width: 300px;
left: 0;
top: 0;
border-radius: 10px;
margin: 0 auto;
}
.topcontent {
height: 300px;
border: 1px solid #BD503A;
background-color: #BD503A;
border-radius: 10px 10px 50% 50% / 10px 10px 15% 15%;
box-shadow: 0px 4px 0px -1px rgba(0,0,0,0.2);
}
#redpack-open {
width: 100px;
height: 100px;
border: 1px solid #FFA73A;
background-color: #FFA73A;
border-radius: 50%;
color: #fff;
font-size: 20px;
display: inline-block;
margin-top: -50px;
box-shadow: 0px 4px 0px 0px rgba(0, 0, 0, 0.2);
}
效果如图:
⽤React来区分不同的状态的转换
⽤React.js来实现的话,主要通过判断state来控制红包现在是等待拆开还是已经拆开过,具体的代码
如下import React from 'react'; class ReadPacket extends React.Component {
constructor(props) {
super(props);
this.state = {
animation: false,
status: 0 // 0: 等待拆开 1: 拆开后
};
}
render() {
var bonus = this.props.thanks ? 0 : parseFloat(this.props.surveyInfo.bonus);
if(this.state.status == 0) {
return (
奖励
点击下⽅按钮领取红包
恭喜发财 ⼤吉⼤利
onClick={this.openRedPacket.bind(this)}
>
拆红包
);
} else if (bonus == 0) {
// 谢谢参与
return (
谢谢参与
多多参与的奖励的机会更多哦
style={{cursor:'pointer',textDecoration: 'underline', color: 'white'}}>去我的账户查看
);
} else {
// 显⽰奖励⾦额
return (
{Fixed(2)}
奖励积分已经存⼊您的账户
style={{textDecoration: 'underline'}}>
去我的账户查看积分
);
}
}
stopAnimation() {
this.setState({animation: false});
}
showResult() {
this.setState({status: 1});
}
openRedPacket() {
this.setState({animation: true});
setTimeout(this.stopAnimation.bind(this), 3000);
setTimeout(this.showResult.bind(this), 4000);
}
_toWallet() {
js控制css3动画触发// 跳转到钱包
window.location.hash = '/wallet'; }
}
export default ReadPacket;
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论