微信小程序实现转盘抽奖


Posted in Javascript onSeptember 21, 2020

本文实例为大家分享了微信小程序实现转盘抽奖的具体代码,供大家参考,具体内容如下

效果图如下所示

微信小程序实现转盘抽奖

.wxml

<view class="index">
 <view class="xian"></view>
 <view class="xian"></view>
 <view class="xian"></view>
 <view class="detail">一等奖</view>
 <view class="detail">二等奖</view>
 <view class="detail">三等奖</view>
 <view class="detail">四等奖</view>
 <view class="detail">五等奖</view>
 <view class="detail">六等奖</view>
 <span bindtap="zhuanin" style="transform:rotate({{trasn}}deg);"></span>
</view>

.wxss

.index{
 width: 300px;
 margin: 50rpx calc((100% - 300px) / 2);
 border:1px solid #ffcccc;
 border-radius: 50%;
 height: 300px;
 position: relative;
 overflow: hidden;
 font-size: 26rpx;
}
.xian{
 width:300px;
 height:1px;
 background:#d6d6d6;
 position:absolute;
 top:150px;
 left:0;
}
.index>.xian:nth-child(2){
 transform:rotateZ(60deg)
}
.index>.xian:nth-child(3){
 transform:rotateZ(120deg)
}
.detail{
 position: absolute;
}
.index>.detail:nth-child(4){
 top:25px;left:132px;
}
.index>.detail:nth-child(5){
 top:90px;left:225px;
}
.index>.detail:nth-child(6){
 top:190px;left:225px;
}
.index>.detail:nth-child(7){
 top:250px;left:132px;
}
.index>.detail:nth-child(8){
 top:190px;left:40px;
}
.index>.detail:nth-child(9){
 top:90px;left:40px;
}
.index>span{
 width: 30px;
 height: 30px;
 background-color: #ffcccc;
 border-radius: 50%;
 position: absolute;
 left: 135px;
 top:135px;
}
.index>span::after{
 content: ' ';
 width:0;
 height:0;
 border-right:6px solid transparent;
 border-left:6px solid transparent;
 border-bottom:26px solid #ffcccc;
 z-index: 10;
 position: absolute;
 left: 8.5px;
 top: -24px;
}

.js

Page({
 data: {
 random:'',
 trasn:0,
 },
 zhuanin:function(e){
 let that = this
 let num = 0
 that.setData({
  random:Math.floor(Math.random() * 360),
  trasn:0,
 })
 let a = setInterval(function () {
  that.setData({
  trasn:that.data.trasn+5
  })
  if(360 <= that.data.trasn){
  that.data.trasn = 0
  num = num + 1
  }
  if(num == 3){
  that.currinl()
  clearInterval(a)
  }
 },5)
 },
 currinl:function(e){
 let that = this
 let name = ''
 if(that.data.random == 30 || that.data.random == 90 || that.data.random == 150 || that.data.random == 210 || that.data.random == 330){
  that.setData({
  random:that.data.random + 1
  })
 }
 if(that.data.random < 30 || 330 < that.data.random){
  name = '一等奖'
 }else if(that.data.random > 30 && that.data.random < 90){
  name = '二等奖'
 }else if(that.data.random > 90 && that.data.random < 150){
  name = '三等奖'
 }else if(that.data.random > 150 && that.data.random < 210){
  name = '四等奖'
 }else if(that.data.random > 210 && that.data.random < 270){
  name = "五等奖"
 }else{
  name = "六等奖"
 }
 let b = setInterval(function () {
  that.setData({
  trasn:that.data.trasn+2
  })
  if(that.data.random <= that.data.trasn){
  wx.showToast({
   title: name,
   icon: 'none',
   duration: 2000
  })
  clearInterval(b)
  }
 },10)
 },
})

为大家推荐现在关注度比较高的微信小程序教程一篇:《微信小程序开发教程》小编为大家精心整理的,希望喜欢。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript客户端脚本的设计和应用
Aug 21 Javascript
图标线性回归斜着移动到指定的位置
Aug 16 Javascript
js 判断控件获得焦点的示例代码
Mar 04 Javascript
使用jquery实现以post打开新窗口
Mar 19 Javascript
JQuery中DOM事件绑定用法详解
Jun 13 Javascript
JS+CSS实现闪烁字体效果代码
Apr 05 Javascript
js实现可控制左右方向的无缝滚动效果
May 29 Javascript
基于vue.js实现图片轮播效果
Dec 01 Javascript
使用live-server快速搭建本地服务器+自动刷新的方法
Mar 09 Javascript
Angular5升级RxJS到5.5.3报错:EmptyError: no elements in sequence的解决方法
Apr 09 Javascript
jquery检测上传文件大小示例
Apr 26 jQuery
vue3使用vue-router的完整步骤记录
Jun 20 Vue.js
结合axios对项目中的api请求进行封装操作
Sep 21 #Javascript
微信小程序实现打卡签到页面
Sep 21 #Javascript
微信小程序实现签到弹窗动画
Sep 21 #Javascript
解决vue prop传值default属性如何使用,为何不生效的问题
Sep 21 #Javascript
微信小程序实现日历签到
Sep 21 #Javascript
Vue切换Tab动态渲染组件的操作
Sep 21 #Javascript
js实现购物车商品数量加减
Sep 21 #Javascript
You might like
咖啡的化学
2021/03/03 咖啡文化
php一句话cmdshell新型 (非一句话木马)
2009/04/18 PHP
PHP中HTML标签过滤技巧
2014/01/07 PHP
PHP防范SQL注入的具体方法详解(测试通过)
2014/05/09 PHP
浅谈htmlentities 、htmlspecialchars、addslashes的使用方法
2016/12/09 PHP
Laravel中日期时间处理包Carbon的简单使用
2017/09/21 PHP
PHP mongodb操作类定义与用法示例【适合mongodb2.x和mongodb3.x】
2018/06/16 PHP
PHP simplexml_load_string()函数实例讲解
2019/02/03 PHP
javascript innerText和innerHtml应用
2010/01/28 Javascript
让js弹出窗口居前显示的实现方法
2013/07/10 Javascript
Jquery动态进行图片缩略的原理及实现
2013/08/13 Javascript
与Math.pow 相反的函数使用介绍
2014/08/04 Javascript
JavaScript中textRange对象使用方法小结
2015/03/24 Javascript
javascript多行字符串的简单实现方式
2015/05/04 Javascript
javascript中递归函数用法注意点
2015/07/30 Javascript
JavaScript数据结构之二叉查找树的定义与表示方法
2017/04/12 Javascript
BootStrap表单控件之复选框checkbox和单选择按钮radio
2017/05/23 Javascript
Vue2仿淘宝实现省市区三级联动
2020/04/15 Javascript
如何实现小程序与小程序之间的跳转
2020/11/04 Javascript
python获得图片base64编码示例
2014/01/16 Python
python中numpy.zeros(np.zeros)的使用方法
2017/11/07 Python
在Python dataframe中出生日期转化为年龄的实现方法
2018/10/20 Python
记录Python脚本的运行日志的方法
2019/06/05 Python
python opencv 读取图片 返回图片某像素点的b,g,r值的实现方法
2019/07/03 Python
Clarks鞋法国官方网站:英国其乐鞋品牌
2018/02/11 全球购物
拉斯维加斯酒店、演出、旅游、俱乐部及更多:Vegas.com
2019/02/28 全球购物
英国网上电器商店:Electricshop
2020/03/15 全球购物
荷兰浴室和卫浴网上商店:Badkamerxxl.nl
2020/10/06 全球购物
物流专业毕业生推荐信范文
2013/11/18 职场文书
毕业生个人求职信范文分享
2014/01/05 职场文书
幼儿园校车司机的岗位职责
2014/01/30 职场文书
数学与统计学院学生个人职业生涯规划书
2014/02/10 职场文书
教师节促销活动方案
2014/02/14 职场文书
家庭教育的心得体会
2014/09/01 职场文书
法定代表人资格证明书
2014/09/11 职场文书
python实现手机推送 代码也就10行左右
2022/04/12 Python