




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第微信小程序?qū)崿F(xiàn)走馬燈式抽獎(jiǎng)本文實(shí)例為大家分享了微信小程序?qū)崿F(xiàn)走馬燈式抽獎(jiǎng)的具體代碼,供大家參考,具體內(nèi)容如下
先來看下效果
設(shè)置獎(jiǎng)項(xiàng)
awardList是從后臺(tái)拿到的獎(jiǎng)項(xiàng)數(shù)組,list不夠八位時(shí)填充謝謝參與獎(jiǎng)項(xiàng),超過八位時(shí)截取數(shù)組,然后隨機(jī)打亂數(shù)組,保證獎(jiǎng)項(xiàng)隨機(jī)布局,第四位固定填充立即抽獎(jiǎng)按鈕
//設(shè)置獎(jiǎng)項(xiàng)
settingAward(awardList){
constlen=awardList.length;
constaward={
awardName:'謝謝參與',
awardMoney:0,
awardType:'00',
awardCode:''
};
let_awardList=[];
if(len8){
for(leti=0;i8-len;i++){
awardList.push(JSON.parse(JSON.stringify(award)));
}
this.randArr(awardList);
_awardList=awardList;
console.log(_awardList)
}elseif(awardList.length==8)_awardList=awardList;
else{
_awardList=awardList.splice(0,9);
}
_awardList.splice(4,0,{
awardName:'立即抽獎(jiǎng)'
})
return_awardList;
//隨機(jī)打亂獎(jiǎng)項(xiàng)
randArr(arr){
for(vari=0;iarr.length;i++){
variRand=parseInt(arr.length*Math.random());
vartemp=arr[i];
arr[i]=arr[iRand];
arr[iRand]=temp;
}
returnarr;
}
布局
主要用了flex布局,遍歷獎(jiǎng)品list,index==4時(shí)渲染立即抽獎(jiǎng)按鈕,否則渲染獎(jiǎng)項(xiàng)
view
viewwx:for="{{awardList}}"
viewwx:if="{{index==4}}"
viewwx:if="{{activityCount0}}"class="btn{{lucking'lucking':'lucked'}}"
textcatchtap="startLuck"{{item.awardName}}/text
/view
viewwx:else
text{{item.awardName}}/text
/view
/view
viewwx:elseclass="award{{currentIndex==index'selected':'unselected'}}"
blockwx:if="{{item.awardType=='00'}}"
view
imagesrc="../../img/noluck_icon.png"/image
/view
view{{item.awardName}}/view
/block
blockwx:elif="{{item.awardType=='07'}}"
view
imagesrc="../../img/mianxi_icon.png"/image
/view
view{{item.awardName}}/view
/block
blockwx:else
view
imagesrc="../../img/turntable_redpacket.png"/image
text{{util.formatMoney(item.awardMoney)}}/text
/view
view{{item.awardName}}/view
/block
/view
/view
/view
抽獎(jiǎng)邏輯
開始抽獎(jiǎng)時(shí)默認(rèn)選中第一個(gè),初始化idArr為currentIndex的索引,即下一個(gè)獎(jiǎng)項(xiàng)在哪激活
記錄圈數(shù)letcycles=0;
開始設(shè)置interval=setInterval(frame,100);
index==8時(shí)輪詢了一圈,cycles加一
當(dāng)cycles2時(shí)減速定時(shí)器interval=setInterval(frame,300);
當(dāng)抽獎(jiǎng)接口有結(jié)果且轉(zhuǎn)了三圈后跳到獲獎(jiǎng)位置,清除定時(shí)器并彈出獲獎(jiǎng)結(jié)果彈窗
//開始抽獎(jiǎng)
startLuck(){
constidArr=[0,1,2,5,8,7,6,3];
letcycles=0;
letthat=this;
let_awardList=this.data.awardList;
letindex=this.data.currentIndex;
letactivityCount=this.data.activityCount-1;
varinterval=setInterval(frame,100);
this.setData({
lucking:true,
activityCount
})
letpending=true;
post('122201.app',{
duration:2000,
activityCode:this.data.activityCode
},{
isMarket:true
}).then(res={
pending=false;
this.setData({
awardResult:{
awardCode:"",
...res
}
})
}).catch(err={
clearInterval(interval);
pending=false;
activityCount+=1;
this.setData({
activityCount,
lucking:false,
})
})
functionframe(){
if(!pending){
//轉(zhuǎn)三圈后跳到獲獎(jiǎng)位置
if(cycles3){
if(_awardList[that.data.currentIndex].awardCode==that.data.awardResult.awardCode){
clearInterval(interval);
that.setData({
lucking:false,
showModal:true
})
return;
}
}
}
if(index==8){
index=0;
if(!pending){
//兩圈后轉(zhuǎn)盤減速
if(cycles++1){
clearInterval(interval);
interval=setInterval(frame,300);
}
}
}
//設(shè)置獎(jiǎng)項(xiàng)跳到對應(yīng)位置
that.setData({
currentIndex:idArr[index++]
})
}
},
wxss
.turntable.content{
width:568rpx;
height:568rpx;
background:#F48002;
border-radius:20px;
position:absolute;
top:90rpx;
left:30rpx;
display:flex;
flex-wrap:wrap;
justify-content:space-around;
align-items:center;
padding:10rpx;
box-sizing:border-box;
.turntable.cont
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 中國智慧高速公路行業(yè)市場發(fā)展現(xiàn)狀及前景趨勢與投資分析研究報(bào)告(2024-2030)
- 健康知識(shí)普及課件
- 健康的生活-生物課件
- 2024年標(biāo)簽貼紙項(xiàng)目項(xiàng)目投資申請報(bào)告代可行性研究報(bào)告
- 營銷全業(yè)務(wù)管控管理辦法
- 蚌埠市數(shù)據(jù)共享管理辦法
- 街道辦事處考勤管理辦法
- 西藏大學(xué)勤工儉學(xué)管理辦法
- 裝修與機(jī)電配合管理辦法
- 西咸新區(qū)自行車管理辦法
- (2024年)中華人民共和國環(huán)境保護(hù)法全
- 委托付款雙方協(xié)議中英文版
- 2023-2024屆高考語文復(fù)習(xí)小說訓(xùn)練-沈從文《邊城》(含答案)
- CSR法律法規(guī)及其他要求清單(RBA)2024.3
- 三方股東協(xié)議合同范本
- 4G5G 移動(dòng)通信技術(shù)-華為4G基站設(shè)備
- 安裝工作業(yè)安全操作規(guī)程
- 2021屆高考語文+選拔性考點(diǎn):小說、散文閱讀中的“選材特點(diǎn)”公開課
- 高中英語選擇性必修一詞匯表默寫版含答案(人教版2019)
- 樓梯維修施工方案
- GB/T 40681.2-2023生產(chǎn)過程能力和性能監(jiān)測統(tǒng)計(jì)方法第2部分:時(shí)間相依過程模型的過程能力與性能
評論
0/150
提交評論