欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信小程序轉(zhuǎn)盤抽獎的實(shí)現(xiàn)方法

 更新時間:2022年07月27日 17:21:31   作者:羽筠  
這篇文章主要為大家詳細(xì)介紹了微信小程序轉(zhuǎn)盤抽獎的實(shí)現(xiàn)方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了微信小程序?qū)崿F(xiàn)轉(zhuǎn)盤抽獎的具體代碼,供大家參考,具體內(nèi)容如下

lucky-draw.wxss:

.lucky_draw_zp{ width: 502rpx; height: 502rpx; margin: 0 auto; position: relative;}
.lucky_draw_zp_img , .lucky_draw_zp_btn{ width: 100%; height: 100%; position: absolute; left: 0; top: 0;}

lucky-draw.wxml:

<view class="lucky_draw_zp" bindtap="getLucky">
?? ?<image style="{{zpRotateDeg}}" class="lucky_draw_zp_img" src="{{zpData.zpImg}}" mode="aspectFit"></image>
?? ?<image class="lucky_draw_zp_btn" src="../../../images/zp_btn.png" mode="aspectFit"></image>
</view>

lucky-draw.js:

?Page({
?
?? ?/**
?? ? * 頁面的初始數(shù)據(jù)
?? ? */
?? ?data: {
?? ??? ?zpData:{
?? ??? ??? ?//轉(zhuǎn)盤主圖圖片url
?? ??? ??? ?zpImg:'../../../images/zp.png',
?? ??? ??? ?
?? ??? ??? ?equalParts:null, //一共多少等份
?? ??? ??? ?oneAngle:null, //每一等份多少度
?? ??? ??? ?
?? ??? ??? ?// ******** 轉(zhuǎn)盤獎品數(shù)據(jù):后臺獲取數(shù)據(jù) ********
?? ??? ??? ?//注:根據(jù)轉(zhuǎn)盤圖片對應(yīng)的值(轉(zhuǎn)盤圖片指針處順時針向右數(shù),起始1,獎品對應(yīng)的格子數(shù)【第幾等份上】)
?? ??? ??? ?awardSetting:[
?? ??? ??? ??? ?'第1個格子對應(yīng)內(nèi)容',
?? ??? ??? ??? ?'第2個格子對應(yīng)內(nèi)容',
?? ??? ??? ??? ?'第3個格子對應(yīng)內(nèi)容',
?? ??? ??? ??? ?'第4個格子對應(yīng)內(nèi)容',
?? ??? ??? ??? ?'第5個格子對應(yīng)內(nèi)容',
?? ??? ??? ??? ?'第6個格子對應(yīng)內(nèi)容',
?? ??? ??? ?],
?? ??? ?},
?? ??? ?
?? ??? ?ifRoate:false, //轉(zhuǎn)盤是否在轉(zhuǎn)動(判斷阻止多次點(diǎn)擊)
?? ??? ?zpRotateDeg:'', //旋轉(zhuǎn)角度
?? ??? ?
?? ??? ?// ******** 抽獎結(jié)果數(shù)據(jù):后臺獲取數(shù)據(jù) ********
?? ??? ?curKey:null, //抽獎結(jié)果 : 取值范圍 1 至 總格子數(shù)
?? ??? ?ifWinning:null, //是否中獎
?? ?},
?
?
?
?
?? ?// 獲取轉(zhuǎn)盤初始數(shù)據(jù)
?? ?getZpData(){
?? ??? ?let zpImg = 'zpData.zpImg';
?? ??? ?let awardSetting = 'zpData.awardSetting';
?? ??? ?this.setData({
?? ??? ??? ?[zpImg]:'../../../images/zp.png',
?? ??? ??? ?[awardSetting]:[
?? ??? ??? ??? ?'1',
?? ??? ??? ??? ?'2',
?? ??? ??? ??? ?'3',
?? ??? ??? ??? ?'4',
?? ??? ??? ??? ?'5',
?? ??? ??? ??? ?'6',
?? ??? ??? ?],
?? ??? ?});
?? ??? ?
?? ??? ?this.setZpDefault();
?? ?},
?? ?// 根據(jù)轉(zhuǎn)盤初始數(shù)據(jù)設(shè)置轉(zhuǎn)盤初始關(guān)鍵參數(shù)
?? ?setZpDefault(){
?? ??? ?let equalPartsNum = this.data.zpData.awardSetting.length;
?? ??? ?let oneAngleNum = 360 / equalPartsNum;
?? ??? ?let equalParts = 'zpData.equalParts';
?? ??? ?let oneAngle = 'zpData.oneAngle';
?? ??? ?this.setData({
?? ??? ??? ?//一共多少等份
?? ??? ??? ?[equalParts] : equalPartsNum,
?? ??? ??? ?// 根據(jù)轉(zhuǎn)盤得等份數(shù)設(shè)置 每一等份多少度
?? ??? ??? ?[oneAngle] : oneAngleNum,
?? ??? ?});
?? ?},
?
?
?? ?// 設(shè)置旋轉(zhuǎn)動效
?? ?setToRotate(degNum){
?? ??? ?this.setData({
?? ??? ??? ?zpRotateDeg : '-webkit-transform: rotate(' + degNum + 'deg);transform: rotate(' + degNum + 'deg);-webkit-transition: all 5s ease;transition: all 5s ease;',
?? ??? ?});
?? ?},
?? ?//根據(jù) 設(shè)置的 指針停止時指向的格子(中獎結(jié)果),設(shè)置其旋轉(zhuǎn)角度區(qū)間
?? ?setRotate(awardSettingNumber){ //awardSettingNumber ?取值范圍 1 至 總格子數(shù)
?? ??? ?setTimeout(() => {
?? ??? ??? ?//轉(zhuǎn)盤停止時 指針 指向的格子 最小角度
?? ??? ??? ?let minAngle = 360 - awardSettingNumber * this.data.zpData.oneAngle + 5;
?? ??? ??? ?//轉(zhuǎn)盤停止時 指針 指向的格子 最大角度
?? ??? ??? ?let maxAngle = 360 - (awardSettingNumber - 1) * this.data.zpData.oneAngle - 5;
?? ??? ??? ?//旋轉(zhuǎn)區(qū)間
?? ??? ??? ?let newAngle = Math.floor(minAngle + Math.random() * (maxAngle - minAngle)) + 360 * 15;
?? ??? ??? ?
?? ??? ??? ?this.setToRotate(newAngle);
?? ??? ??? ?
?? ??? ??? ?setTimeout(() => {
?? ??? ??? ??? ?this.roateEnd(awardSettingNumber);
?? ??? ??? ?}, 5150);
?? ??? ?},50);
?? ?},
?? ?//旋轉(zhuǎn)結(jié)束執(zhí)行
?? ?roateEnd(awardSettingNumber){
?? ??? ?console.log('當(dāng)前指向格子數(shù) -- ' + awardSettingNumber , this.data.curKey);
?? ??? ?console.log('當(dāng)前指向格子數(shù)對應(yīng)內(nèi)容 -- ' + this.data.zpData.awardSetting[awardSettingNumber - 1] , this.data.zpData.awardSetting[this.data.curKey - 1]);
?? ??? ?
?? ??? ?// 是否中獎
?? ??? ?if(this.data.ifWinning){
?? ??? ??? ?console.log('中獎');
?? ??? ?}else{
?? ??? ??? ?console.log('未中獎');
?? ??? ?}
?? ??? ?
?? ??? ?setTimeout(() => {
?? ??? ??? ?this.setData({
?? ??? ??? ??? ?ifRoate : false, //轉(zhuǎn)盤是否在轉(zhuǎn)動
?? ??? ??? ?});
?? ??? ?}, 100);
?? ?},
?
?
?? ?//點(diǎn)擊抽獎
?? ?getLucky(){
?? ??? ?if(this.data.ifRoate){
?? ??? ??? ?return false;
?? ??? ?}
?? ??? ?
?? ??? ?this.setData({
?? ??? ??? ?ifRoate : true, //轉(zhuǎn)盤是否在轉(zhuǎn)動
?? ??? ??? ?zpRotateDeg : ''
?? ??? ?});
?? ??? ??? ??? ?
?? ??? ?// 請求后臺獲取抽獎結(jié)果中...
?? ??? ?
?? ??? ?/*test*/
?? ??? ?var res = {
?? ??? ??? ?status:1,
?? ??? ??? ?curKey:Math.floor(1 + Math.random() * this.data.zpData.equalParts), //抽獎結(jié)果 : 取值范圍 1 至 總格子數(shù)
?? ??? ??? ?ifWinning:true, //是否中獎
?? ??? ??? ?info:'沒機(jī)會或什么什么'
?? ??? ?}
?? ??? ?/*test*/
?? ??? ?
?? ??? ?/
?? ??? ??? ?if(res.status == 1){
?? ??? ??? ??? ?this.setData({
?? ??? ??? ??? ??? ?curKey : res.curKey,
?? ??? ??? ??? ??? ?ifWinning : res.ifWinning
?? ??? ??? ??? ?});
?? ??? ??? ??? ?
?? ??? ??? ??? ?this.setRotate(this.data.curKey);
?? ??? ??? ?}else{
?? ??? ??? ??? ?this.setData({
?? ??? ??? ??? ??? ?ifRoate : false, //轉(zhuǎn)盤是否在轉(zhuǎn)動
?? ??? ??? ??? ?});
?? ??? ??? ??? ?wx.showModal({
?? ??? ??? ??? ??? ?title: '溫馨提示',
?? ??? ??? ??? ??? ?showCancel:false,
?? ??? ??? ??? ??? ?content: res.info,
?? ??? ??? ??? ?})
?? ??? ??? ?}
?? ??? ?/
?? ?},
?
?
?? ?/**
?? ? * 生命周期函數(shù)--監(jiān)聽頁面加載
?? ? */
?? ?onLoad: function (options) {
?
?? ?},
?
?? ?/**
?? ? * 生命周期函數(shù)--監(jiān)聽頁面初次渲染完成
?? ? */
?? ?onReady: function () {
?
?? ?},
?
?? ?/**
?? ? * 生命周期函數(shù)--監(jiān)聽頁面顯示
?? ? */
?? ?onShow: function () {
?? ??? ?this.getZpData();
?? ?},
?
?? ?/**
?? ? * 生命周期函數(shù)--監(jiān)聽頁面隱藏
?? ? */
?? ?onHide: function () {
?
?? ?},
?
?? ?/**
?? ? * 生命周期函數(shù)--監(jiān)聽頁面卸載
?? ? */
?? ?onUnload: function () {
?
?? ?},
?
?? ?/**
?? ? * 頁面相關(guān)事件處理函數(shù)--監(jiān)聽用戶下拉動作
?? ? */
?? ?onPullDownRefresh: function () {
?
?? ?},
?
?? ?/**
?? ? * 頁面上拉觸底事件的處理函數(shù)
?? ? */
?? ?onReachBottom: function () {
?
?? ?},
?
?? ?/**
?? ? * 用戶點(diǎn)擊右上角分享
?? ? */
?? ?onShareAppMessage: function () {
?
?? ?}
})

圖片資源:

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

相關(guān)文章

  • js數(shù)組反轉(zhuǎn)的幾種常見方法舉例

    js數(shù)組反轉(zhuǎn)的幾種常見方法舉例

    最近學(xué)到了數(shù)組的使用方法,給大家分享一下,這篇文章主要給大家介紹了關(guān)于js數(shù)組反轉(zhuǎn)的幾種常見方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-10-10
  • 基于JS實(shí)現(xiàn)二維碼圖片固定在右下角某處并跟隨滾動條滾動

    基于JS實(shí)現(xiàn)二維碼圖片固定在右下角某處并跟隨滾動條滾動

    這篇文章主要介紹了基于JS實(shí)現(xiàn)二維碼圖片固定在右下角某處并跟隨滾動條滾動,代碼簡單易懂非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-02-02
  • JavaScript實(shí)現(xiàn)長圖滾動效果

    JavaScript實(shí)現(xiàn)長圖滾動效果

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)長圖滾動效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-04-04
  • 特殊日期提示功能的實(shí)現(xiàn)方法

    特殊日期提示功能的實(shí)現(xiàn)方法

    這篇文章主要介紹了特殊日期提示功能的實(shí)現(xiàn)方法的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-06-06
  • javascript object array方法使用詳解

    javascript object array方法使用詳解

    在javascript開發(fā)中經(jīng)常會使用到array中方法,本文將對其一一詳細(xì)介紹,需要了解的朋友可以參考下
    2012-12-12
  • 深入淺出聊一聊js中的'this'關(guān)鍵字

    深入淺出聊一聊js中的'this'關(guān)鍵字

    js中的this關(guān)鍵字平時在開發(fā)中使用時倒是也能正常應(yīng)用,但是對其使用和判斷并不能信手拈來,所以下面這篇文章主要給大家介紹了關(guān)于js中this關(guān)鍵字的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • js獲取url傳值的方法

    js獲取url傳值的方法

    這篇文章主要介紹了js獲取url傳值的方法,實(shí)例分析了字符串分割與正則分析兩種方法,并補(bǔ)充了一個基于正則匹配實(shí)現(xiàn)的js獲取url的get傳值函數(shù),需要的朋友可以參考下
    2015-12-12
  • js的math中缺少的數(shù)學(xué)方法小結(jié)

    js的math中缺少的數(shù)學(xué)方法小結(jié)

    JavaScript?Math對象包含一些真正有用且強(qiáng)大的數(shù)學(xué)運(yùn)算,但它缺乏大多數(shù)其他語言提供的許多重要運(yùn)算,例如求和,乘積,奇數(shù)和偶數(shù)等等,本文就來介紹一下
    2023-08-08
  • 詳解js樹形控件—zTree使用總結(jié)

    詳解js樹形控件—zTree使用總結(jié)

    本篇文章主要介紹了js樹形控件—zTree使用總結(jié),樹形控件的使用是應(yīng)用開發(fā)過程中必不可少的。zTree 是一個依靠 jQuery 實(shí)現(xiàn)的多功能 “樹插件”。優(yōu)異的性能、靈活的配置、多種功能的組合是 zTree 最大優(yōu)點(diǎn).
    2016-12-12
  • JS sort方法基于數(shù)組對象屬性值排序

    JS sort方法基于數(shù)組對象屬性值排序

    這篇文章主要介紹了JS sort方法基于數(shù)組對象屬性值排序,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-07-07

最新評論