当前位置: 首页 > news >正文

微信小程序之九宫格抽奖

1.实现效果

九宫格

2. 实现步骤

话不多说,直接上代码

/**index.wxml*/
<view class="table-list flex fcc fwrap"><block wx:for="{{tableList}}" wx:key="id"><view class="table-item btn fcc {{isTurnOver?'':'grayscale'}}" wx:if="{{item.type=='btn'}}" bind:tap="onPrizeClick">{{item.name}}</view><view class="table-item fcc {{item.isSelected?'selected':''}}" wx:else>{{item.name}}</view></block>
</view>
import { showTextToast } from '../../utils/util';// pages/turnTable/index.js
Page({/*** 页面的初始数据*/data: {tableList: [{ id: '1', type: 'prize', name: '奖品1', isSelected: false },{ id: '2', type: 'prize', name: '奖品2', isSelected: false },{ id: '3', type: 'prize', name: '奖品3', isSelected: false },{ id: '4', type: 'prize', name: '奖品8', isSelected: false },{ id: '5', type: 'btn', name: '抽奖', isSelected: false },{ id: '6', type: 'prize', name: '奖品4', isSelected: false },{ id: '7', type: 'prize', name: '奖品7', isSelected: false },{ id: '8', type: 'prize', name: '奖品6', isSelected: false },{ id: '9', type: 'prize', name: '奖品5', isSelected: false },],isTurnOver: true, //抽奖状态,是否旋转完(九宫格)},/*** 生命周期函数--监听页面加载*/onLoad(options) {},/*** 生命周期函数--监听页面初次渲染完成*/onReady() {},/*** 生命周期函数--监听页面显示*/onShow() {},/****************************************** 九宫格抽奖 *******************************/onPrizeClick() {//如果不在抽奖状态中,则执行抽奖旋转动画if (this.data.isTurnOver) {this.setData({isTurnOver: false,});// 随机奖品效果const rand = (m, n) => {return Math.ceil(Math.random() * (n - m + 1) + m - 1);};let prizeId = rand(1, 8);this.lottery(prizeId);} else {showTextToast('请勿重复点击');}},// 抽奖旋转动画方法lottery(prize_id) {console.log('中奖ID:' + prize_id);/** 数组的长度就是最多所转的圈数,最后一圈会转到中奖后的位置* 数组里面的数字表示从一个奖品跳到另一个奖品所需要的时间* 数字越小速度越快* 想要修改圈数和速度的,更改数组个数和大小即可*/// let num_interval_arr = [90, 80, 70, 60, 50, 50, 50, 100, 150, 250];let num_interval_arr = [90, 80, 70, 60, 50, 50, 250];// 旋转的总次数let sum_rotate = num_interval_arr.length;// 每一圈所需要的时间let interval = 0;num_interval_arr.forEach((delay, index) => {setTimeout(() => {this.rotateCircle(delay, index + 1, sum_rotate, prize_id);}, interval);//因为每一圈转完所用的时间是不一样的,所以要做一个叠加操作interval += delay * 8;});},/**** @param {*} delay 表示一个奖品跳到另一个奖品所需要的时间* @param {*} index 表示执行到第几圈* @param {*} sum_rotate 表示旋转的总圈数* @param {*} prize_id 中奖的id号*/rotateCircle(delay, index, sum_rotate, prize_id) {// console.log(index)let _this = this;/** 页面中奖项的实际数组下标* 0  1  2* 3     5* 6  7  8* 所以得出转圈的执行顺序数组为 ↓*/let order_arr = [0, 1, 2, 5, 8, 7, 6, 3];// 页面奖品总数组let tableList = this.data.tableList;// 如果转到最后一圈,把数组截取到奖品项的位置if (index == sum_rotate) {order_arr.splice(prize_id);}console.log(order_arr);for (let i = 0; i < order_arr.length; i++) {setTimeout(() => {// 清理掉选中的状态tableList.forEach((e) => {e.isSelected = false;});// 执行到第几个就改变它的选中状态tableList[order_arr[i]].isSelected = true;// 更新状态_this.setData({tableList: tableList,});// 如果转到最后一圈且转完了,把抽奖状态改为已经转完了if (index == sum_rotate && i == order_arr.length - 1) {_this.setData({isTurnOver: true,});}}, delay * i);}},
});
.table-list {width: 100%;box-sizing: border-box;.table-item {width: 200rpx;height: 200rpx;margin-bottom: 10rpx;background-color: orange;color: #fff;border:5rpx solid snow;}.table-item.btn {background-color: gold;}.table-item.selected {background-color: orangered;}.table-item.turn {background-color: goldenrod;}

相关文章:

  • 【python】python社交交友平台系统设计与实现(源码+数据库)【独一无二】
  • 【C++】多态(多态的原理)
  • es数据备份和迁移Elasticsearch
  • 邮件系统中的CC和BCC含义
  • 第十章 DashBoard
  • 从零开始傅里叶变换
  • Design-expert中的ANOVA分析
  • 搜维尔科技:第九届元宇宙数字人设计大赛入围作品名单
  • 如何设计与构建企业IT数字化运维体系与目标
  • 使用 ASM 修改字段类型,解决闪退问题
  • 如何*永久*禁用edge打开PDF文件?
  • 高中数学:平面向量-数量积(向量与向量的乘积)与投影
  • Spring Cloud Alibaba-08-SMS短信服务
  • 逐元素比较
  • CSS动画技术(css-animation)
  • CSS3 变换
  • Java Agent 学习笔记
  • js面向对象
  • MySQL数据库运维之数据恢复
  • Node 版本管理
  • Promise面试题,控制异步流程
  • Python利用正则抓取网页内容保存到本地
  • XForms - 更强大的Form
  • 欢迎参加第二届中国游戏开发者大会
  • 使用 @font-face
  • 思维导图—你不知道的JavaScript中卷
  • 通过几道题目学习二叉搜索树
  • 我建了一个叫Hello World的项目
  • 中国人寿如何基于容器搭建金融PaaS云平台
  • Java数据解析之JSON
  • UI设计初学者应该如何入门?
  • 阿里云移动端播放器高级功能介绍
  • ​软考-高级-系统架构设计师教程(清华第2版)【第15章 面向服务架构设计理论与实践(P527~554)-思维导图】​
  • (1)Android开发优化---------UI优化
  • (poj1.2.1)1970(筛选法模拟)
  • (Python第六天)文件处理
  • (二十四)Flask之flask-session组件
  • (剑指Offer)面试题34:丑数
  • (考研湖科大教书匠计算机网络)第一章概述-第五节1:计算机网络体系结构之分层思想和举例
  • (原創) 如何刪除Windows Live Writer留在本機的文章? (Web) (Windows Live Writer)
  • (转载)跟我一起学习VIM - The Life Changing Editor
  • .NET Core SkiaSharp 替代 System.Drawing.Common 的一些用法
  • .NET 服务 ServiceController
  • .net 使用ajax控件后如何调用前端脚本
  • .Net程序猿乐Android发展---(10)框架布局FrameLayout
  • .NET框架
  • .net知识和学习方法系列(二十一)CLR-枚举
  • @Transient注解
  • [ C++ ] STL---stack与queue
  • [ 网络通信基础 ]——网络的传输介质(双绞线,光纤,标准,线序)
  • [] 与 [[]], -gt 与 > 的比较
  • []C/C++读取串口接收到的数据程序
  • [android] 看博客学习hashCode()和equals()
  • [android] 练习PopupWindow实现对话框
  • [BZOJ1053][HAOI2007]反素数ant