公司项目搞优惠活动,让做一个转盘抽奖的活动,转盘抽奖让他转起来 按照概率停止其实都麻烦,但是概率如果设置在前端就会很大的安全漏洞,所以无论为了安全性还是后期的维护问题都要把概率写到后台配置里然后读取配置。那么问题来了,我们需要把后台的概率结果和前端自己的转盘想对应,我的大致思路是这样的,后台返回概率结果之后,对应的可定有奖品,然后给每个奖品一个不变的标识,根据这个返回的标识我们前端进行相应的转盘指针停留的位置。我们后台鼻尖懒 他不想改接口了 就直接让我去对应配置里的奖品名字,好吧就这样算是搞完了。
var myDraw;//点击转盘方法名
var $btn = $(‘.turntableBox‘);
$(‘#playnum‘).html(playnum);
var isture = false;
var myPriceName;
var prizeValue;
if(isture == true){
$(‘.turntableBox‘).unbind("touchend",myDraw);
}else{
$(‘.turntableBox‘).bind("touchend",myDraw);
}
function zhuanpan(){
$.ajax({
type:"post",
url: "",
async:false,
data:{
account:account,
userType:userType
},
beforeSend:function(){
$(‘.turntableBox‘).unbind("touchend",myDraw);
},
success:function(data){
console.log(data);
myPriceName = data.data.prizeName;
prizeValue = data.data.prizeValue;//产品价值
localStorage.setItem("prizeValue",prizeValue);
},error:function(XMLHttpRequest, textStatus, errorThrown){
alert("转盘-"+XMLHttpRequest.status);
alert("转盘-"+XMLHttpRequest.readyState);
alert("转盘-"+textStatus);
},
complete:function(){
$(‘.turntableBox‘).bind("touchend",myDraw);
}
});
}
var clickfunc = function() {
zhuanpan();
var data = myPriceName;
if(data == ‘0‘){
rotateFunc(18, ‘恭喜您获得0‘);
setTimeout(hongbao,6000)
}
if(data == ‘1‘){
rotateFunc(54, ‘恭喜您获得1‘);
}
if(data == ‘2‘){
rotateFunc(90, ‘恭喜您获得2!‘);
}
if(data == ‘3‘){
rotateFunc(126, ‘恭喜您获得3!‘);
}
if(data == ‘4‘){
rotateFunc(162, ‘恭喜您获得4‘);
}
if(data == ‘5‘){
rotateFunc(198, ‘恭喜您获得5!‘);
}
if(data == ‘6‘){
rotateFunc(234, ‘恭喜您获得6!‘);
}
if(data == ‘7‘){
rotateFunc(270, ‘恭喜您获得7!‘);
}
if(data == ‘8‘){
rotateFunc(306, ‘恭喜您获得8!‘);
}
if(data == ‘9‘){
rotateFunc(342, ‘9!‘);
}
}
$btn.bind(‘touchend‘,myDraw =function(){
shareTimes();//抽奖次数
if(isture) return; // 如果在执行就退出
isture = true; // 标志为 在执行
//先判断是否登录,未登录则执行下面的函数
if(1 == 2) {
$(‘#playnum‘).html(‘0‘);
alert("请先登录");
isture = false;
} else { //登录了就执行下面
if(playnum <= 0) { //当抽奖次数为0的时候执行
// alert("对不起,您没有次数了!");
$(‘.myAlert‘).html(‘对不起,您没有抽奖次数!‘).show ().delay (1000).fadeOut ();
$(‘#playnum‘).html(0);
isture = false;
} else { //还有次数就执行
// $(‘.turntableBox‘).bind("touchend",myDraw);
playnum = playnum - 1; //执行转盘了则次数减1
if(playnum <= 0) {
playnum = 0;
}
$(‘#playnum‘).html(playnum);
clickfunc();
}
}
});
var rotateFunc = function(angle, text){
isture = true;
$btn.stopRotate();
$btn.rotate({
angle: 10,
duration: 1500, //旋转时间
animateTo: angle + 1080, //让它根据得出来的结果加上1080度旋转
callback: function() {
isture = false; // 标志为 执行完毕
$(‘.myAlert‘).html(text).show ().delay (1500).fadeOut ();
}
});
};
}
在这个程序员苦逼的年代里我们需要抱团取暖