




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第微信小程序?qū)崿F(xiàn)走馬燈式抽獎(jiǎng)本文實(shí)例為大家分享了微信小程序?qū)崿F(xiàn)走馬燈式抽獎(jiǎng)的具體代碼,供大家參考,具體內(nèi)容如下
先來(lái)看下效果
設(shè)置獎(jiǎng)項(xiàng)
awardList是從后臺(tái)拿到的獎(jiǎng)項(xiàng)數(shù)組,list不夠八位時(shí)填充謝謝參與獎(jiǎng)項(xiàng),超過(guò)八位時(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)邏輯
開(kāi)始抽獎(jiǎng)時(shí)默認(rèn)選中第一個(gè),初始化idArr為currentIndex的索引,即下一個(gè)獎(jiǎng)項(xiàng)在哪激活
記錄圈數(shù)letcycles=0;
開(kāi)始設(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é)果彈窗
//開(kāi)始抽獎(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)盤(pán)減速
if(cycles++1){
clearInterval(interval);
interval=setInterval(frame,300);
}
}
}
//設(shè)置獎(jiǎng)項(xiàng)跳到對(duì)應(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. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 膩?zhàn)雍贤瑓f(xié)議書(shū)
- 還錢(qián)合同協(xié)議書(shū)
- 生理學(xué)試題集及答案
- 運(yùn)輸收入考試試題及答案
- 現(xiàn)成合同協(xié)議書(shū)
- 軟件共同開(kāi)發(fā)協(xié)議合同
- 汽車轉(zhuǎn)贈(zèng)協(xié)議書(shū)
- 車尾箱租賃合同協(xié)議
- 車位認(rèn)購(gòu)協(xié)議合同書(shū)
- 增資合同協(xié)議書(shū)有利
- 02R112 拱頂油罐圖集
- 水工程施工復(fù)習(xí)
- 《歸園田居》其三
- 2023年上海等級(jí)考政治試卷及答案
- GB/T 5018-2008潤(rùn)滑脂防腐蝕性試驗(yàn)法
- GB/T 2951.13-2008電纜和光纜絕緣和護(hù)套材料通用試驗(yàn)方法第13部分:通用試驗(yàn)方法-密度測(cè)定方法-吸水試驗(yàn)-收縮試驗(yàn)
- GB/T 13793-2016直縫電焊鋼管
- GB/T 12221-2005金屬閥門(mén)結(jié)構(gòu)長(zhǎng)度
- GB/T 10125-2021人造氣氛腐蝕試驗(yàn)鹽霧試驗(yàn)
- 科邁ComApMRS16發(fā)電機(jī)組控制器說(shuō)明書(shū)
- 石油天然氣管道系統(tǒng)治安風(fēng)險(xiǎn)等級(jí)和安全防范要求說(shuō)課講解
評(píng)論
0/150
提交評(píng)論