vue實(shí)現(xiàn)大轉(zhuǎn)盤抽獎功能
本文實(shí)例為大家分享了vue實(shí)現(xiàn)大轉(zhuǎn)盤抽獎的具體代碼,供大家參考,具體內(nèi)容如下
效果圖如下
中獎提示
代碼如下
<template> ? <div class="dial" v-wechat-title="$route.meta.title"> ? ? <div class="times">抽獎次數(shù){{LuckyClick}}</div> ? ? <!-- 轉(zhuǎn)盤包裹 --> ? ? <div class="rotate"> ? ? ? <!-- 繪制圓點(diǎn) --> ? ? ? <div ? ? ? ? :class="'circle circle_'+index" ? ? ? ? v-for="(item,index) in circleList" ? ? ? ? :key="index" ? ? ? ? :style="{background:index%2==0?colorCircleFirst:colorCircleSecond}" ? ? ? ></div> ? ? ? <!-- 轉(zhuǎn)盤圖片 --> ? ? ? <img ? ? ? ? class="dish" ? ? ? ? src="../../assets/dial.png" ? ? ? ? :style="{transform:rotate_deg,transition:rotate_transition}" ? ? ? /> ? ? ? <!-- 指針圖片 --> ? ? ? <img class="pointer" src="../../assets/click.png" @click="start" /> ? ? </div> ? </div> </template> ? <script> var light_timer; //燈光定時器 ? export default { ? name: "dial", ? data() { ? ? return { ? ? ? LuckyClick: 3, ? ? ? circleList: [], //原點(diǎn)設(shè)置 ? ? ? colorCircleFirst: "#FE4D32", //圓點(diǎn)顏色 ? ? ? colorCircleSecond: "#fff", //圓點(diǎn)顏色 ? ? ? ? cat: 45, //總共8個扇形區(qū)域,每個區(qū)域約45度 ? ? ? isAllowClick: true, //是否能夠點(diǎn)擊 ? ? ? rotate_deg: 0, //指針旋轉(zhuǎn)的角度 ? ? ? rotate_transition: "transform 3s ease-in-out" //初始化選中的過度屬性控制 ? ? }; ? }, ? ? components: { ? ? // Calendar: Calendar ? }, ? created() { ? ? this.showcircleList(); ? }, ? ? watch: {}, ? ? mounted() {}, ? ? methods: { ? ? //繪制圓點(diǎn)設(shè)置 ? ? showcircleList() { ? ? ? let circleList = []; ? ? ? for (var i = 0; i < 16; i++) { ? ? ? ? circleList.push(i); ? ? ? } ? ? ? this.circleList = circleList; ? ? ? this.light(); ? ? }, ? ? ? //閃動效果 ? ? light: function() { ? ? ? var that = this; ? ? ? clearInterval(light_timer); ? ? ? light_timer = setInterval(function() { ? ? ? ? if (that.colorCircleFirst == "#FE4D32") { ? ? ? ? ? that.colorCircleFirst = "#fff"; ? ? ? ? ? that.colorCircleSecond = "#FE4D32"; ? ? ? ? } else { ? ? ? ? ? that.colorCircleFirst = "#FE4D32"; ? ? ? ? ? that.colorCircleSecond = "#fff"; ? ? ? ? } ? ? ? }, 300); //設(shè)置圓點(diǎn)閃爍的效果 ? ? }, ? ? ? start() { ? ? ? if (this.LuckyClick == 0) { ? ? ? ? alert("機(jī)會已經(jīng)用完了"); ? ? ? ? return; ? ? ? } ? ? ? this.rotating(); ? ? }, ? ? ? rotating() { ? ? ? if (!this.isAllowClick) return; ? ? ? this.isAllowClick = false; ? ? ? this.rotate_transition = "transform 3s ease-in-out"; ? ? ? this.LuckyClick--; ? ? ? var rand_circle = 5; //默認(rèn)多旋轉(zhuǎn)5圈 ? ? ? // ? var winningIndex = Math.floor(Math.random() * 8); //獲獎的下標(biāo) ? 0-7 ? 沒有概率每個平均 ? ? ? var winningIndex = this.set(); //設(shè)置了概率的 ? ? ? ? console.log(winningIndex); ? ? ? var randomDeg = 360 - winningIndex * 45; //當(dāng)前下標(biāo)對應(yīng)的角度 ? ?45是總共8個扇形區(qū)域,每個區(qū)域約45度 ? ? ? ? var deg = rand_circle * 360 + randomDeg; //將要旋轉(zhuǎn)的度數(shù) ?由于是順時針的轉(zhuǎn)動方向需要用360度來減 ? ? ? this.rotate_deg = "rotate(" + deg + "deg)"; ? ? ? ? var that = this; ? ? ? setTimeout(function() { ? ? ? ? that.isAllowClick = true; ? ? ? ? that.rotate_deg = "rotate(" + 0 + "deg)"; //定時器關(guān)閉的時候重置角度 ? ? ? ? that.rotate_transition = ""; ? ? ? ? ? if (winningIndex == 0) { ? ? ? ? ? alert("恭喜您,IphoneX"); ? ? ? ? } else if (winningIndex == 1) { ? ? ? ? ? alert("恭喜您,獲得10元現(xiàn)金"); ? ? ? ? } else if (winningIndex == 2) { ? ? ? ? ? alert("很遺憾,重在參與"); ? ? ? ? } else if (winningIndex == 3) { ? ? ? ? ? alert("恭喜您,獲得30元現(xiàn)金"); ? ? ? ? } else if (winningIndex == 4) { ? ? ? ? ? alert("恭喜您,獲得20元現(xiàn)金"); ? ? ? ? } else if (winningIndex == 5) { ? ? ? ? ? alert("恭喜您,獲得50元現(xiàn)金"); ? ? ? ? } else if (winningIndex == 6) { ? ? ? ? ? alert("恭喜您,獲得5元現(xiàn)金"); ? ? ? ? } else if (winningIndex == 7) { ? ? ? ? ? alert("恭喜您,獲得100元現(xiàn)金"); ? ? ? ? } ? ? ? }, 3500); ? ? }, ? ? ? //設(shè)置概率 ? ? set() { ? ? ? var winIndex; ? ? //方法1 ? ? // ? if (Math.floor(Math.random() * 100) < 30) { ? ? // ? ? console.log("30%的概率,重在參與"); ? ? // ? ? winIndex = 2; ? ? // ? } else if (Math.floor(Math.random() * 100) < 55) { ? ? // ? ? console.log("25%的概率,5元"); ? ? // ? ? winIndex = 6; ? ? // ? } else if (Math.floor(Math.random() * 100) < 75) { ? ? // ? ? console.log("20%的概率,10元"); ? ? // ? ? winIndex = 1; ? ? // ? } else if (Math.floor(Math.random() * 100) < 85) { ? ? // ? ? console.log("10%的概率,20元"); ? ? // ? ? winIndex = 4; ? ? // ? } else if (Math.floor(Math.random() * 100) < 92) { ? ? // ? ? console.log("7%的概率,30元"); ? ? // ? ? winIndex = 3; ? ? // ? } else if (Math.floor(Math.random() * 100) < 97) { ? ? // ? ? console.log("5%的概率,50元"); ? ? // ? ? winIndex = 5; ? ? // ? } else if (Math.floor(Math.random() * 100) < 99) { ? ? // ? ? console.log("2%的概率,100元"); ? ? // ? ? winIndex = 7; ? ? // ? } else if (Math.floor(Math.random() * 100) == 99) { ? ? // ? ? console.log("1%的概率,IphoneX"); ? ? // ? ? winIndex = 0; ? ? // ? } ? ? ?? ? ? ? ? //方法2 ? ? ? var __rand__ = Math.random(); ? ? ? if (__rand__ < 0.3) winIndex = 2; ? ? ? else if (__rand__ < 0.55) winIndex = 6; ? ? ? else if (__rand__ < 0.75) winIndex = 1; ? ? ? else if (__rand__ < 0.85) winIndex = 4; ? ? ? else if (__rand__ < 0.92) winIndex = 3; ? ? ? else if (__rand__ < 0.97) winIndex = 5; ? ? ? else if (__rand__ < 0.99) winIndex = 7; ? ? ? else if (__rand__ = 0.99) winIndex = 0; ? ? ? ? return winIndex; ? ? } ? }, ? ? computed: {} }; </script> ? ? <style ?scoped lang="scss"> @import "../../common/common"; .times { ? text-align: center; ? line-height: 0.8rem; ? background: #fff; } .rotate { ? width: 6.1rem; ? height: 6.1rem; ? background: #ffbe04; ? border-radius: 50%; ? display: flex; ? flex-direction: column; ? align-items: center; ? justify-content: center; ? position: absolute; ? top: 48%; ? left: 50%; ? transform: translate(-50%, -50%); } ? .rotate .dish { ? width: 5.5rem; ? height: 5.5rem; } ? .pointer { ? width: 1.39rem; ? height: 2.03rem; ? position: absolute; ? top: 46%; ? left: 50%; ? transform: translate(-50%, -50%); } ? /* 圓點(diǎn) */ .rotate .circle { ? position: absolute; ? display: block; ? border-radius: 50%; ? height: 0.16rem; ? width: 0.16rem; ? background: black; } ? .rotate .circle_0 { ? top: 0.08rem; ? left: 2.92rem; } ? .rotate .circle_1 { ? top: 0.28rem; ? left: 4.05rem; } ? .rotate .circle_2 { ? top: 0.86rem; ? left: 4.95rem; } ? .rotate .circle_3 { ? top: 1.85rem; ? left: 5.65rem; } ? .rotate .circle_4 { ? top: 2.85rem; ? right: 0.1rem; } ? .rotate .circle_5 { ? bottom: 1.89rem; ? right: 0.29rem; } ? .rotate .circle_6 { ? bottom: 0.96rem; ? right: 0.88rem; } ? .rotate .circle_7 { ? bottom: 0.34rem; ? right: 1.76rem; } ? .rotate .circle_8 { ? bottom: 0.06rem; ? right: 3.06rem; } ? .rotate .circle_9 { ? bottom: 0.28rem; ? left: 1.9rem; } ? .rotate .circle_10 { ? bottom: 0.96rem; ? left: 0.88rem; } ? .rotate .circle_11 { ? bottom: 1.82rem; ? left: 0.28rem; } ? .rotate .circle_12 { ? top: 2.9rem; ? left: 0.1rem; } ? .rotate .circle_13 { ? top: 1.9rem; ? left: 0.28rem; } ? .rotate .circle_14 { ? top: 1rem; ? left: 0.86rem; } ? .rotate .circle_15 { ? top: 0.32rem; ? left: 1.76rem; } </style>
本文中用到的圖片
大轉(zhuǎn)盤圖片如下
指針的圖片如下:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- vue3實(shí)現(xiàn)抽獎模板設(shè)置
- Vue組件實(shí)現(xiàn)數(shù)字滾動抽獎效果
- vue實(shí)現(xiàn)宮格輪轉(zhuǎn)抽獎
- VUE實(shí)現(xiàn)大轉(zhuǎn)盤抽獎
- vue簡單實(shí)現(xiàn)轉(zhuǎn)盤抽獎
- vue組件實(shí)現(xiàn)移動端九宮格轉(zhuǎn)盤抽獎
- Vue.js實(shí)現(xiàn)大轉(zhuǎn)盤抽獎總結(jié)及實(shí)現(xiàn)思路
- 基于VUE實(shí)現(xiàn)的九宮格抽獎功能
- vue實(shí)現(xiàn)手機(jī)號碼抽獎上下滾動動畫示例
- vue組件封裝實(shí)現(xiàn)抽獎隨機(jī)數(shù)
相關(guān)文章
Vue 兩個字段聯(lián)合校驗(yàn)之修改密碼功能的實(shí)現(xiàn)
本文以校驗(yàn)兩次密碼的一致性應(yīng)用,給出兩個可變屬性值的字段之間的聯(lián)合校驗(yàn)的典型解決方案,通過實(shí)例代碼給大家介紹Vue 兩個字段聯(lián)合校驗(yàn)之修改密碼功能的實(shí)現(xiàn),需要的朋友一起看看吧2021-07-07Vue+ECharts實(shí)現(xiàn)中國地圖的繪制及各省份自動輪播高亮顯示
這篇文章主要介紹了Vue+ECharts實(shí)現(xiàn)中國地圖的繪制以及拖動、縮放和各省份自動輪播高亮顯示,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-12-12Vue實(shí)現(xiàn)鼠標(biāo)懸浮隱藏與顯示圖片效果@mouseenter和@mouseleave事件詳解
在所做的Vue項(xiàng)目中,有時候需要在鼠標(biāo)移動文字框的時候顯示一些詳細(xì)信息,下面這篇文章主要給大家介紹了關(guān)于Vue實(shí)現(xiàn)鼠標(biāo)懸浮隱藏與顯示圖片效果@mouseenter和@mouseleave事件的相關(guān)資料,需要的朋友可以參考下2022-11-11詳解vuex 中的 state 在組件中如何監(jiān)聽
本篇文章主要介紹了詳解vuex 中的 state 在組件中如何監(jiān)聽,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05element-ui tree結(jié)構(gòu)實(shí)現(xiàn)增刪改自定義功能代碼
這篇文章主要介紹了element-ui tree結(jié)構(gòu)實(shí)現(xiàn)增刪改自定義功能代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08vue實(shí)現(xiàn)的上拉加載更多數(shù)據(jù)/分頁功能示例
這篇文章主要介紹了vue實(shí)現(xiàn)的上拉加載更多數(shù)據(jù)/分頁功能,涉及基于vue的事件響應(yīng)、數(shù)據(jù)交互等相關(guān)操作技巧,需要的朋友可以參考下2019-05-05