
本文操作环境:windows7系统、Vue2.9.6版、Dell G3电脑。
vuejs 可以做转盘吗?
Vue中可配置的圆形抽奖转盘组件
一、整个抽奖流程的思路分析:
- 点击了转盘正中间的指针(即开始抽奖按钮),判断是否可以转动(具体逻辑封装在
canBeRotated()里–①当前拥有的抽奖次数是否大于0②现在是否正在转动着(被锁着)),判断通过则进行下一步, 否则弹出相应提示。 - 获取转盘应该停止的位置,应该与后台交互,但这里仅作演示用途, 本地随机抽取0~5。
- 与后台交互成功获取到该停止的位置后,锁定转盘且减少抽奖次数。
- 告诉转盘组件,开始转动了,并且动画结束后停在步骤2设置的地方。
- 转盘转动,停在步骤3设置的地方后再提示中奖,解锁。
二、圆形抽奖转盘组件需要做的事情
- 可以自定义每一格转盘的背景颜色,外边框的颜色。(
turntableStyleOption属性) - 转盘的大小与位置。(在调用时,给组件加个class,代码里为
turntable) - 自定义这个转盘运转起来要转过的圈数。(
rotateCircle属性) - 可以自定义运转动画的时长。(
duringTime属性) - 通过接收到父组件传递过来的奖品信息(
prizeData),显示在每一格转盘的位置。(计算要根据圆心旋转的角度getRotateAngle()方法) - 被父组件调用后就开始转动,并在指定位置停下的方法(
rotate),结束动画后告诉父组件已停下。 - 奖品的名称和图片可以自定义样式。
三、页面预览

四、基础用法
- 引用
import roundTurntable from './components/roundTurntable';
- 声明
components: {
roundTurntable
},
- 调用
<round-turntable
ref="roundTurntable"
:prizeData="prizeData"
:rotateCircle="rotateCircle"
:duringTime="duringTime"
:turntableStyleOption="turntableStyleOption"
@endRotation="endRotation"
class="turntable">
<template slot="item" slot-scope="scope">
<p class="turntable-name">{{ scope.item.prizeName }}</p>
<p class="turntable-img">
<img :src="scope.item.prizeImg">
</p>
</template>
</round-turntable>
data() {
return {
// 转盘上的奖品数据
prizeData: [
{
id: 1,
prizeName: '2000元京东券',
prizeImg: 'http://demo.sc.chinaz.net/Files/DownLoad/webjs1/201803/jiaoben5789/images/1.png',
},
{
id: 2,
prizeName: '300元京东券',
prizeImg: 'http://demo.sc.chinaz.net/Files/DownLoad/webjs1/201803/jiaoben5789/images/7.png',
},
{
id: 3,
prizeName: '50个比特币',
prizeImg: 'http://demo.sc.chinaz.net/Files/DownLoad/webjs1/201803/jiaoben5789/images/3.png',
},
{
id: 4,
prizeName: '50元话费券',
prizeImg: 'http://demo.sc.chinaz.net/Files/DownLoad/webjs1/201803/jiaoben5789/images/4.png',
},
{
id: 5,
prizeName: '100元话费券',
prizeImg: 'http://demo.sc.chinaz.net/Files/DownLoad/webjs1/201803/jiaoben5789/images/5.png',
},
{
id: 6,
prizeName: '100个比特币',
prizeImg: 'http://demo.sc.chinaz.net/Files/DownLoad/webjs1/201803/jiaoben5789/images/6.png',
}
],
// 转动的圈数
rotateCircle: 6,
// 转动需要持续的时间(s)
duringTime: 4.5,
// 转盘样式的选项
turntableStyleOption: {
// 背景色
prizeBgColors: ['#AE3EFF', '#4D3FFF', '#FC262C', '#3A8BFF', '#EE7602', '#FE339F'],
// 转盘的外边框颜色
borderColor: '#199301',
},
}
},
methods: {
// 已经转动完转盘触发的函数
endRotation() {
// 提示中奖
alert(`恭喜您获奖啦,您的奖品是:${this.prizeData[this.prizeIndex].prizeName}`);
},
},
.turntable {
position: absolute;
left: calc(50% - 200px);
top: calc(50% - 200px);
width: 400px;
height: 400px;
}
.turntable-name {
/*background: pink;*/
position: absolute;
left: 10px;
top: 20px;
width: calc(100% - 20px);
font-size: 26px;
text-align: center;
color: #fff;
}
.turntable-img {
position: absolute;
/*要居中就要50% - 宽度 / 2*/
left: calc(50% - 80px / 2);
top: 60px;
width: 80px;
height: 80px;
img {
display: inline-block;
width: 100%;
height: 100%;
}
}
五、roundTurntable组件的属性说明
| 参数 | 说明 | 类型 | 默认值 |
|---|---|---|---|
| ref | 获取这组件的dom节点,调用子组件的开始转动动画方法要用到this.$refs[refName].rotate(index) |
string | — |
| prizeData | 显示在转盘上的奖品数据 | array | — |
| rotateCircle | 转盘要转过的圈数 | number | 6 |
| duringTime | 转动需要持续的时间(单位为秒s) |
number | 4.5 |
| turntableStyleOption | 转盘的样式选项(背景色、外边框颜色) | object | { prizeBgColors: ['#AE3EFF', '#4D3FFF', '#FC262C', '#3A8BFF', '#EE7602', '#FE339F'], borderColor: '#199301' } |
| class | 用来定义转盘位置和大小的样式 | string | — |
六、roundTurntable组件的事件说明
| 事件名称 | 说明 | 回调参数 |
|---|---|---|
| endRotation | 转盘停下来后触发的事件回调 | — |
七、完整项目代码
https://github.com/LiaPig/vue-round-turntable
使用到的奖品图片和指针图片均来自:
http://sc.chinaz.com/jiaobendemo.aspx?downloadid=12018113053246
以上就是vuejs 可以做转盘吗的详细内容,更多请关注亿码酷站其它相关文章!
<!–
–>vuejs 可以做转盘吗
—–文章转载自PHP中文网如有侵权请联系ymkuzhan@126.com删除
转载请注明来源:vuejs 可以做转盘吗
本文永久链接地址:https://www.ymkuzhan.com/43376.html
本文永久链接地址:https://www.ymkuzhan.com/43376.html
下载声明:
本站资源如无特殊说明默认解压密码为www.ymkuzhan.com建议使用WinRAR解压; 本站资源来源于用户分享、互换、购买以及网络收集等渠道,本站不提供任何技术服务及有偿服务,资源仅提供给大家学习研究请勿作它用。 赞助本站仅为维持服务器日常运行并非购买程序及源码费用因此不提供任何技术支持,如果你喜欢该程序,请购买正版! 版权声明:
下载本站资源学习研究的默认同意本站【版权声明】若本站提供的资源侵犯到你的权益,请提交版权证明文件至邮箱ymkuzhan#126.com(将#替换为@)站长将会在三个工作日内为您删除。 免责声明:
您好,本站所有资源(包括但不限于:源码、素材、工具、字体、图像、模板等)均为用户分享、互换、购买以及网络收集而来,并未取得原始权利人授权,因此禁止一切商用行为,仅可用于个人研究学习使用。请务必于下载后24小时内彻底删除,一切因下载人使用所引起的法律相关责任,包括但不限于:侵权,索赔,法律责任,刑事责任等相关责任,全部由下载人/使用人,全部承担。以上说明,一经发布视为您已全部阅读,理解、同意以上内容,如对以上内容持有异议,请勿下载,谢谢配合!支持正版,人人有责,如不慎对您的合法权益构成侵犯,请联系我们对相应内容进行删除,谢谢!


