欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue實(shí)現(xiàn)大轉(zhuǎn)盤(pán)抽獎(jiǎng)功能

 更新時(shí)間:2022年03月08日 11:28:50   作者:面壁思過(guò)程  
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)大轉(zhuǎn)盤(pán)抽獎(jiǎng)功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了vue實(shí)現(xiàn)大轉(zhuǎn)盤(pán)抽獎(jiǎng)的具體代碼,供大家參考,具體內(nèi)容如下

效果圖如下

中獎(jiǎng)提示

代碼如下

<template>
? <div class="dial" v-wechat-title="$route.meta.title">
? ? <div class="times">抽獎(jiǎng)次數(shù){{LuckyClick}}</div>
? ? <!-- 轉(zhuǎn)盤(pá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)盤(pá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; //燈光定時(shí)器
?
export default {
? name: "dial",
? data() {
? ? return {
? ? ? LuckyClick: 3,
? ? ? circleList: [], //原點(diǎn)設(shè)置
? ? ? colorCircleFirst: "#FE4D32", //圓點(diǎn)顏色
? ? ? colorCircleSecond: "#fff", //圓點(diǎn)顏色
?
? ? ? cat: 45, //總共8個(gè)扇形區(qū)域,每個(gè)區(qū)域約45度
? ? ? isAllowClick: true, //是否能夠點(diǎn)擊
? ? ? rotate_deg: 0, //指針旋轉(zhuǎn)的角度
? ? ? rotate_transition: "transform 3s ease-in-out" //初始化選中的過(guò)度屬性控制
? ? };
? },
?
? 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();
? ? },
?
? ? //閃動(dòng)效果
? ? 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ī)會(huì)已經(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); //獲獎(jiǎng)的下標(biāo) ? 0-7 ? 沒(méi)有概率每個(gè)平均
? ? ? var winningIndex = this.set(); //設(shè)置了概率的
?
? ? ? console.log(winningIndex);
? ? ? var randomDeg = 360 - winningIndex * 45; //當(dāng)前下標(biāo)對(duì)應(yīng)的角度 ? ?45是總共8個(gè)扇形區(qū)域,每個(gè)區(qū)域約45度
?
? ? ? var deg = rand_circle * 360 + randomDeg; //將要旋轉(zhuǎn)的度數(shù) ?由于是順時(shí)針的轉(zhuǎn)動(dòng)方向需要用360度來(lái)減
? ? ? this.rotate_deg = "rotate(" + deg + "deg)";
?
? ? ? var that = this;
? ? ? setTimeout(function() {
? ? ? ? that.isAllowClick = true;
? ? ? ? that.rotate_deg = "rotate(" + 0 + "deg)"; //定時(shí)器關(guān)閉的時(shí)候重置角度
? ? ? ? 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)盤(pán)圖片如下

指針的圖片如下:

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue 兩個(gè)字段聯(lián)合校驗(yàn)之修改密碼功能的實(shí)現(xiàn)

    Vue 兩個(gè)字段聯(lián)合校驗(yàn)之修改密碼功能的實(shí)現(xiàn)

    本文以校驗(yàn)兩次密碼的一致性應(yīng)用,給出兩個(gè)可變屬性值的字段之間的聯(lián)合校驗(yàn)的典型解決方案,通過(guò)實(shí)例代碼給大家介紹Vue 兩個(gè)字段聯(lián)合校驗(yàn)之修改密碼功能的實(shí)現(xiàn),需要的朋友一起看看吧
    2021-07-07
  • Vue+ECharts實(shí)現(xiàn)中國(guó)地圖的繪制及各省份自動(dòng)輪播高亮顯示

    Vue+ECharts實(shí)現(xiàn)中國(guó)地圖的繪制及各省份自動(dòng)輪播高亮顯示

    這篇文章主要介紹了Vue+ECharts實(shí)現(xiàn)中國(guó)地圖的繪制以及拖動(dòng)、縮放和各省份自動(dòng)輪播高亮顯示,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-12-12
  • Vue實(shí)現(xiàn)鼠標(biāo)懸浮隱藏與顯示圖片效果@mouseenter和@mouseleave事件詳解

    Vue實(shí)現(xiàn)鼠標(biāo)懸浮隱藏與顯示圖片效果@mouseenter和@mouseleave事件詳解

    在所做的Vue項(xiàng)目中,有時(shí)候需要在鼠標(biāo)移動(dòng)文字框的時(shí)候顯示一些詳細(xì)信息,下面這篇文章主要給大家介紹了關(guān)于Vue實(shí)現(xiàn)鼠標(biāo)懸浮隱藏與顯示圖片效果@mouseenter和@mouseleave事件的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • 詳解vuex 中的 state 在組件中如何監(jiān)聽(tīng)

    詳解vuex 中的 state 在組件中如何監(jiān)聽(tīng)

    本篇文章主要介紹了詳解vuex 中的 state 在組件中如何監(jiān)聽(tīng),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05
  • vue 中filter的多種用法

    vue 中filter的多種用法

    這篇文章主要介紹了vue 中filter的多種用法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2018-04-04
  • 使用@tap.stop阻止事件繼續(xù)傳播

    使用@tap.stop阻止事件繼續(xù)傳播

    這篇文章主要介紹了使用@tap.stop阻止事件繼續(xù)傳播,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • element-ui tree結(jié)構(gòu)實(shí)現(xiàn)增刪改自定義功能代碼

    element-ui tree結(jié)構(gòu)實(shí)現(xiàn)增刪改自定義功能代碼

    這篇文章主要介紹了element-ui tree結(jié)構(gòu)實(shí)現(xiàn)增刪改自定義功能代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-08-08
  • vue中使用props傳值的方法

    vue中使用props傳值的方法

    這篇文章主要介紹了vue中使用props傳值的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • vue實(shí)現(xiàn)的上拉加載更多數(shù)據(jù)/分頁(yè)功能示例

    vue實(shí)現(xiàn)的上拉加載更多數(shù)據(jù)/分頁(yè)功能示例

    這篇文章主要介紹了vue實(shí)現(xiàn)的上拉加載更多數(shù)據(jù)/分頁(yè)功能,涉及基于vue的事件響應(yīng)、數(shù)據(jù)交互等相關(guān)操作技巧,需要的朋友可以參考下
    2019-05-05
  • vue中v-model對(duì)select的綁定操作

    vue中v-model對(duì)select的綁定操作

    這篇文章主要介紹了vue中v-model對(duì)select的綁定操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-08-08

最新評(píng)論