亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

微信小程序?qū)崿F(xiàn)多宮格抽獎活動

 更新時間:2020年04月15日 15:20:29   作者:西江無月  
這篇文章主要為大家詳細介紹了微信小程序?qū)崿F(xiàn)多宮格抽獎功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

最近閑來無事,做了一個多宮格抽獎的例子,有什么需要改進或者錯誤的地方,請留言,謝謝

首先看效果:

思路是先讓其轉(zhuǎn)動2圈多,然后再進行抽獎,格子運動用的是setTimeout,讓其運行的時間間隔不一樣,然后產(chǎn)生運動快慢的效果

好了,上代碼

首先是WXML(這里面的判斷可能有些繞,仔細按順序看,因其第五個和第十一個格子在不同手機屏幕大小上的顯示有問題,所以再次給它們判斷了一下)

<view class="box">
 <view class="boxsub {{luckynum==index?'luck':''}}" wx:for='{{box}}' style="{{index>0&&index<4?'top:0;left:'+index*140+'rpx;':(index>3&&index<8?'right:0;top:'+((index-4)*100)+'rpx;':(index>7&&index<12?'bottom:0;right:'+(index-7)*140+'rpx;':(index>11&&index<14?'left:0;bottom:'+(index-11)*100+'rpx;':'')))}} {{index=='4'?'top:0;':''}} {{index=='11'?'left:0;':''}} " wx:key=''>
  <text class='boxcontent' style='{{item.name.length>6?"line-height:40rpx;margin-top:10rpx;":"line-height:100rpx;"}}'>{{item.name}}</text> 
 
 </view>
 <view class="lucky" catchtap="luckyTap">
 <text class="taplucky">點擊抽獎</text>
 <text class="howMany">您還有<text class="howMany_num" >{{howManyNum}}</text>次抽獎機會</text>
 </view>
</view>
<view class="explain">

</view>

WXSS:

.box{
 margin:20rpx 25rpx;
 height: 400rpx;
 width: 698rpx;
 /*border:1px solid #ddd;*/
 position: relative;
 /*box-sizing: border-box;*/
}
.boxsub{
 width: 140rpx;
 height: 100rpx;
 /*border: 1px solid #f00;*/
 box-sizing: border-box;
 position: absolute;
 background: #ff6100;
 border: 1rpx solid #fff;
 
}
.boxcontent{
 text-align: center;
 font-size: 26rpx;
 display: block;
 color: #fff;
}
.lucky{
 width: 300rpx;
 height:130rpx;
 background:#ff6100;/* #ff6100;007FFF*/
 position: absolute;
 left: 0;
 bottom: 0;
 right: 0;
 top: 0rpx;
 margin: auto;
}

.lucky:active{
 opacity: 0.7;
}
.taplucky{
 display: block;
 text-align: center;
 font-size: 30rpx;
 line-height: 50rpx;
 height: 50rpx;
 color: #fff;
 margin-top: 20rpx;
}
.howMany{
 display: block;
 text-align: center;
 font-size: 26rpx;
 color: #fff;
 line-height: 40rpx;
 height: 40rpx;
}
.howMany_num{
 color:#007FFF;
 font-size:32rpx;
 line-height:40rpx;
 padding:0 10rpx;
}
.luck{
 opacity: 0.5;
 background: #ff6100;
}

JS

var time = null;//setTimeout的ID,用clearTimeout清除
Page({
 data: {
 box: [{
 name:'100積分'
 }, {
 name: '10元優(yōu)惠券\n滿100可用'
 }, {
 name: '60積分'
 }, {
 name: '30積分'
 }, {
 name: '50積分'
 }, {
 name: '30元優(yōu)惠券\n滿120可用'
 }, {
 name: '100積分'
 }, {
 name: '200積分'
 }, {
 name: '10積分'
 }, {
 name: '50積分'
 }, {
 name: '40積分'
 }, {
 name: '50優(yōu)惠券滿500可用'
 }, {
 name: '60積分'
 }, {
 name: '70積分'
 }],
 luckynum:0,//當(dāng)前運動到的位置,在界面渲染
 howManyNum:10,//抽獎的剩余次數(shù)
 content:{
 index: 0, //當(dāng)前轉(zhuǎn)動到哪個位置,起點位置
 count: 0, //總共有多少個位置
 speed: 50, //初始轉(zhuǎn)動速度
 cycle: 3*14, //轉(zhuǎn)動基本次數(shù):即至少需要轉(zhuǎn)動多少次再進入抽獎環(huán)節(jié),這里設(shè)置的是轉(zhuǎn)動三次后進入抽獎環(huán)節(jié)
 },
 prize:0,//中獎的位置
 luckytapif:true//判斷現(xiàn)在是否可以點擊
 },
 //點擊抽獎
 luckyTap:function(){
 var i=0,
 that=this,
 howManyNum = this.data.howManyNum,//剩余的抽獎次數(shù)
 luckytapif = this.data.luckytapif,//獲取現(xiàn)在處于的狀態(tài)
 luckynum = this.data.luckynum,//當(dāng)前所在的格子
 prize =Math.floor(Math.random()*14) ;//中獎序號,隨機生成
 if (luckytapif && howManyNum>0){//當(dāng)沒有處于抽獎狀態(tài)且剩余的抽獎次數(shù)大于零,則可以進行抽獎
 console.log('prize:'+prize);
 this.data.content.count=this.data.box.length;
 this.setData({
 howManyNum:howManyNum-1//更新抽獎次數(shù)
 });
 this.data.luckytapif=false;//設(shè)置為抽獎狀態(tài)
 this.data.prize = prize;//中獎的序號
 this.roll();//運行抽獎函數(shù)
 } else if (howManyNum == 0 && luckytapif){
 wx.showModal({
 title: '',
 content: '您的抽獎次數(shù)已經(jīng)沒有了',
 showCancel:false
 })
 }
 },
//抽獎
 roll:function(){
 var content=this.data.content,
 prize = this.data.prize,//中獎序號
 that=this;
 if (content.cycle - (content.count-prize)>0){//最后一輪的時間進行抽獎
 content.index++;
 content.cycle--;
 this.setData({
 luckynum: content.index%14 //當(dāng)前應(yīng)該反映在界面上的位置
 });
 setTimeout(this.roll, content.speed);//繼續(xù)運行抽獎函數(shù)
 }else{
 if (content.index < (content.count*3 + prize)){//判斷是否停止

 content.index++; 
 content.speed += (550 /14);//最后一輪的速度,勻加速,最后停下時的速度為550+50
 this.data.content=content;
 this.setData({
  luckynum: content.index % 14
 });
 console.log(content.index, content.speed);//打印當(dāng)前的步數(shù)和當(dāng)前的速度
 setTimeout(this.roll,content.speed);
 }else{
 //完成抽獎,初始化數(shù)據(jù)
 console.log('完成');
 content.index =0;
 content.cycle = 3 * 14;
 content.speed = 50;
 this.data.luckytapif = true;
 clearTimeout(time);
 wx.showModal({
  title: '',
  content: '恭喜你抽到了'+that.data.box[prize].name,
  showCancel:false
 })
 }
 }
 },
 onLoad: function (options) {
 
 },
 onReady: function () {
 
 },
 onShow: function () {
 
 },
 onHide: function () {
 
 },
 onUnload: function () {
 
 }
})

完結(jié)。

想要學(xué)習(xí)更多關(guān)于抽獎功能的實現(xiàn),請參考此專題:抽獎功能

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 前端處理文本換行展示4種處理方法

    前端處理文本換行展示4種處理方法

    在處理前端顯示后端傳遞的包含換行符的文本時,可以通過多種方法實現(xiàn)換行顯示,這篇文章主要介紹了前端處理文本換行展示4種處理方法,這些方法幫助前端正確展示格式化文本,解決了文本堆疊的問題,需要的朋友可以參考下
    2024-10-10
  • js實現(xiàn)倒計時關(guān)鍵代碼

    js實現(xiàn)倒計時關(guān)鍵代碼

    這篇文章主要為大家詳細介紹了js實現(xiàn)倒計時的關(guān)鍵代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • 微信小程序動態(tài)添加view組件的實例代碼

    微信小程序動態(tài)添加view組件的實例代碼

    本文通過實例代碼給大家介紹了微信小程序動態(tài)添加view組件的方法,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • JavaScript實現(xiàn)頁面截圖3種解決方案

    JavaScript實現(xiàn)頁面截圖3種解決方案

    網(wǎng)頁截圖是指將網(wǎng)頁上的內(nèi)容截取下來,并保存為圖片的過程,下面這篇文章主要給大家介紹了關(guān)于JavaScript實現(xiàn)頁面截圖的3種解決方案,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-06-06
  • js的隱含參數(shù)(arguments,callee,caller)使用方法

    js的隱含參數(shù)(arguments,callee,caller)使用方法

    本篇文章只要是對js的隱含參數(shù)(arguments,callee,caller)使用方法進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-01-01
  • js計算任意值之間隨機數(shù)的方法

    js計算任意值之間隨機數(shù)的方法

    這篇文章主要介紹了js計算任意值之間隨機數(shù)的方法,分析了Math.random函數(shù)的使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-01-01
  • 使用正則表達式的格式化與高亮顯示json字符串

    使用正則表達式的格式化與高亮顯示json字符串

    這篇文章主要介紹了使用正則表達式的格式化與高亮顯示json字符串的方法,非常的簡單實用,需要的朋友可以參考下
    2014-12-12
  • 微信小程序自定義組件

    微信小程序自定義組件

    這篇文章主要為大家詳細介紹了微信小程序自定義組件的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Active控件問題小結(jié)(附解決辦法)

    Active控件問題小結(jié)(附解決辦法)

    這篇文章主要介紹了Active控件問題小結(jié)(附解決辦法)的相關(guān)資料,非常不錯具有參考借鑒價值,需要的朋友可以參考下
    2016-06-06
  • 前端圖片懶加載的原理與3種實現(xiàn)方式舉例

    前端圖片懶加載的原理與3種實現(xiàn)方式舉例

    圖片懶加載又稱圖片延時加載、惰性加載,即在用戶需要使用圖片的時候加載,這樣可以減少請求,節(jié)省帶寬,提高頁面加載速度,相對的,也能減少服務(wù)器壓力,下面這篇文章主要給大家介紹了關(guān)于前端圖片懶加載的原理與3種實現(xiàn)方式的相關(guān)資料,需要的朋友可以參考下
    2023-03-03

最新評論