<template> <div id="rotary-table"> <div class="award" v-for="(award,index) in awards" :class="['award' index,{'active': index==current}]"> {{award.name}} </div> <div id="start-btn" @click="start">开始</div> </div></template><script> export default{ name: 'raffle', data() { return { current: 0, awards: [ { id: 1, name: '空' }, { id: 2, name: '眼镜' }, { id: 3, name: '包' }, { id: 4, name: '笨驴' }, { id: 5, name: '书' }, { id: 6, name: '手链' }, { id: 7, name: '美女' }, { id: 8, name: 'iphone' } ], speed: 200, diff: 15, award: {}, time: 0 }; }, methods: { start(){ // 开始抽奖 this.drawAward(); this.time = Date.now(); this.speed = 200; this.diff = 15; }, drawAward(){ // 请求接口, 这里我就模拟请求后的数据(请求时间为2s) setTimeout( () => { this.award = { id: '4', name: '笨驴', }; }, 1000 ); this.move(); }, move(){ window.timeout = setTimeout( () => { this.current ; if ( this.current > 7 ) { this.current = 0; } if ( this.award.id && ( Date.now() - this.time ) / 1000 > 2 ) { this.speed = this.diff; if ( ( Date.now() - this.time ) / 1000 > 4 && this.award.id == this.awards[ this.current ].id ) { clearTimeout( window.timeout ); setTimeout( () => { alert( '恭喜你,抽中了' this.award.name ); }, 0 ); return; } } else { this.speed -= this.diff; } console.log( this.speed ); this.move(); }, this.speed ); } } };</script><style rel="stylesheet/less" lang="less"> * { margin: 0; padding: 0; list-style: none; outline: none; } #rotary-table { width: 340px; height: 349px; position: relative; margin: auto; background-color: antiquewhite; .award { width: 90px; height: 96px; line-height: 96px; text-align: center; float: left; position: absolute; overflow: hidden; background-color: aquamarine; &.active { background-color: darkgoldenrod; } &.award0 { top: 21px; left: 21px; } &.award1 { top: 21px; left: 125px; } &.award2 { top: 21px; right: 22px; } &.award3 { top: 126px; right: 22px; } &.award4 { bottom: 22.5px; right: 22px; } &.award5 { bottom: 22.5px; right: 125.5px; } &.award6 { bottom: 22.5px; left: 21px; } &.award7 { top: 126px; left: 21px; } } #start-btn { position: absolute; top: 125px; left: 124px; width: 90px; height: 96px; line-height: 90px; text-align: center; background-color: coral; } }</style>
下载vue实现九宫格抽奖效果用户还喜欢
- 18480 文章数
- 500万+ 热度
作者专栏
编辑推荐
- 淡抹u2引擎,修复内容较多,物有所值
- 界域传说·经典巨作=传世单机(一键安装)
- 丸子版本(175个传世版本大集合)
- GS版本:神话公益服务端+客户端
- 图片放大工具(放大图片不模糊)
- 剪映无限制VIP版
- 传奇世界客户端下载器,史上最全传世客户端
- 传世GS20220920商业引擎注册+登录配置器 解压密码是1
- U2官方排行榜游戏网关 支持元神,支持传家宝
- GS开战传世客户端+服务端
- (淡漠夕阳)u2引擎合区工具
- 传世GS引擎消除“你的游戏客户端版本号过旧,请及时更新”提示
- 传世一机多区双线路配置器--免密码版本
- 传世凤凰登陆器劫持修复软件
- SQLite3 for Navicat
- 传奇世界npc对话框编辑工具
- 传世GS落霞铭文服务器端
- gs_20210409引擎包+注册机(无限制)
- 传奇世界NPC对话封包查看器[支持时长版和极速版]
- 彩虹引擎传世脚本编辑工具1.7版来了,支持函数脚本翻译
评论