Vue.js實(shí)現(xiàn)大轉(zhuǎn)盤(pán)抽獎(jiǎng)總結(jié)及實(shí)現(xiàn)思路
大家好!先上圖看看本次案例的整體效果。
實(shí)現(xiàn)思路:
Vue component實(shí)現(xiàn)大轉(zhuǎn)盤(pán)組件,可以嵌套到任意要使用的頁(yè)面。
css3 transform控制大轉(zhuǎn)盤(pán)抽獎(jiǎng)過(guò)程的動(dòng)畫(huà)效果。
抽獎(jiǎng)組件內(nèi)使用鉤子函數(shù)watch監(jiān)聽(tīng)抽獎(jiǎng)結(jié)果的返回情況播放大轉(zhuǎn)盤(pán)動(dòng)畫(huà)并給用戶彈出中獎(jiǎng)提示。
中獎(jiǎng)結(jié)果彈窗,為抽獎(jiǎng)組件服務(wù)。
實(shí)現(xiàn)步驟如下:
構(gòu)建api獎(jiǎng)品配置信息和抽獎(jiǎng)接口,vuex全局存放獎(jiǎng)品配置和中獎(jiǎng)結(jié)果數(shù)據(jù)信息。
api:
export default { getPrizeList () { let prizeList = [ { id: 1, name: '小米8', img: 'https://i1.mifile.cn/f/i/g/2015/cn-index/m8-140.png' }, { id: 2, name: '小米電視', img: 'https://i1.mifile.cn/f/i/g/2015/TV4A-43QC.png' }, { id: 3, name: '小米平衡車(chē)', img: 'https://i1.mifile.cn/f/i/g/2015/cn-index/scooter-140!140x140.jpg' }, { id: 4, name: '小米耳機(jī)', img: 'https://c1.mifile.cn/f/i/g/2015/video/pinpai140!140x140.jpg' } ] return prizeList }, lottery () { return { id: 4, name: '小米耳機(jī)', img: 'https://c1.mifile.cn/f/i/g/2015/video/pinpai140!140x140.jpg' } } }
store:
import lotteryApi from '../../api/lottery.api.js' const state = { prizeList: [], lotteryResult: {} } const getters = { prizeList: state => state.prizeList, lotteryResult: state => state.lotteryResult } const mutations = { SetPrizeList (state, { prizeList }) { state.prizeList = prizeList }, SetLotteryResult (state, { lotteryResult }) { state.lotteryResult = lotteryResult } } const actions = { getPrizeList ({ commit }) { let result = lotteryApi.getPrizeList() commit('SetPrizeList', { prizeList: result }) }, lottery ({ commit }) { let result = lotteryApi.lottery() commit('SetLotteryResult', { lotteryResult: result }) } } export default { state, getters, mutations, actions, namespaced: true }
編寫(xiě)抽獎(jiǎng)組件,為保證通用性,組件只負(fù)責(zé)播放抽獎(jiǎng)結(jié)果。接收兩個(gè)數(shù)據(jù)和一個(gè)方法,如下:
數(shù)據(jù)一:預(yù)置的獎(jiǎng)品列表數(shù)據(jù)(輪播獎(jiǎng)品需要)
數(shù)據(jù)二:抽獎(jiǎng)結(jié)果,播放抽獎(jiǎng)動(dòng)畫(huà)和彈出中獎(jiǎng)結(jié)果需要
方法:抽獎(jiǎng)動(dòng)作,返回的抽獎(jiǎng)結(jié)果數(shù)據(jù)即為數(shù)據(jù)二,響應(yīng)式傳遞給組件
大概代碼思路如下(僅供參考,不可運(yùn)行)
<template> <section> <div class="lucky-item"> <img src="http://www.cnblogs.com/images/cnblogs_com/codeon/878827/o_backImage.jpg" alt> <div class="lucky-box"> <img src="http://www.cnblogs.com/images/cnblogs_com/codeon/878827/o_circle.jpg" alt> <ul id="wheel" class="wheel-list" :style="wheelStyle" :class="transition"> <li v-for="(prize,index) in slotPrizes" :style="{transform: 'rotate('+index*45+'deg)'}" v-bind:key="index"> <div class="fan-item" style="transform: rotate(15deg) skewY(45deg);"></div> <div class="lucky-prize"> <h3>{{prize.name}}</h3> </div> </li> </ul> <div class="wheel-btn" @click="$emit('lottery')"> <a> <img src="http://images.cnblogs.com/cnblogs_com/codeon/878827/o_go.jpg" alt> </a> </div> </div> <prize-pop :prize="lotteryResult" v-if="showPrize" @closeLotteryPop="showPrize=false" /> </div> </section> </template> <script> import PrizePop from './common/prize-pop.vue' export default { name: 'BigTurntable', data () { return { isStart: false, showPrize: false, wheelStyle: { 'transform': 'rotate(0deg)' }, transition: 'transitionclear', playTurns: 5 // 默認(rèn)先旋轉(zhuǎn)5圈 } }, components: { PrizePop }, props: { prizes: { type: Array, required: false }, lotteryResult: { type: Object, default: () => { } } }, computed: { slotPrizes () { var self = this console.log(self.prizes) let prizeList = [] prizeList.push({ ...self.prizes[0], slotIndex: 1 }) prizeList.push({ name: '謝謝參與', slotIndex: 2 }) prizeList.push({ ...self.prizes[1], slotIndex: 3 }) prizeList.push({ name: '謝謝參與', slotIndex: 4 }) prizeList.push({ ...self.prizes[2], slotIndex: 5 }) prizeList.push({ name: '謝謝參與', slotIndex: 6 }) prizeList.push({ ...self.prizes[3], slotIndex: 7 }) prizeList.push({ name: '謝謝參與', slotIndex: 8 }) console.log(prizeList) return prizeList } }, methods: { /** * 執(zhí)行抽獎(jiǎng)動(dòng)畫(huà) */ playWheel (index) { }, /** * 獲取中獎(jiǎng)結(jié)果所在獎(jiǎng)品列表中的索引,以確定抽獎(jiǎng)動(dòng)畫(huà)最終落在哪個(gè)獎(jiǎng)品 */ getPrizeIndex (prizeId) { } }, watch: { /** * 監(jiān)聽(tīng)抽獎(jiǎng)結(jié)果,一旦有中獎(jiǎng)信息就開(kāi)始執(zhí)行抽獎(jiǎng)動(dòng)畫(huà) */ lotteryResult (newVal, oldVal) { var self = this if (newVal.id && newVal.id > 0) { let index = self.getPrizeIndex(newVal.id) self.playWheel(index) } } } } </script>
彈出中獎(jiǎng)結(jié)果組件,依附于抽獎(jiǎng)組件,在上一步的執(zhí)行抽獎(jiǎng)結(jié)果動(dòng)畫(huà)結(jié)束后執(zhí)行。
<template> <div class="subject-pop" style="z-index: 10;" v-if="prize.id>0"> <div class="subject-pop-mask"></div> <div class="subject-pop-box"> <h3>恭喜您</h3> <p> <img :src="prize.img" alt> </p> <h4>獲得 <span></span> <span>{{prize.name}}</span> </h4> <div class="subject-pop-footer"> <a href="javascript:;" rel="external nofollow" class="november-btn1" @click="closeLotteryEmit">知道了</a> </div> </div> </div> </template> <script> export default { props: { prize: { type: Object, default: () => { return { id: 0 } } } }, methods: { closeLotteryEmit () { this.$emit('closeLotteryPop') } } } </script>
抽獎(jiǎng)組件運(yùn)用在需要使用的頁(yè)面中,此頁(yè)面需要為抽獎(jiǎng)組件提前準(zhǔn)備好預(yù)置獎(jiǎng)品列表和中獎(jiǎng)結(jié)果信息,并提供好抽獎(jiǎng)方法供子組件(抽獎(jiǎng)組件)觸發(fā),觸發(fā)完更改抽獎(jiǎng)結(jié)果響應(yīng)式傳入到抽獎(jiǎng)組件中。
<template> <section> <div style="width:100%;text-align:center;margin:2rem 0;">您有一次抽獎(jiǎng)機(jī)會(huì),祝君好運(yùn)~~~</div> <BigTurntable :prizes="prizeList" :lotteryResult="lotteryResult" @lottery="lottery" /> </section> </template> <script> import { mapGetters, mapActions } from 'vuex' import BigTurntable from '@/components/bigTurntable.vue' export default { name: 'BigTurntableRun', created () { var self = this self.getPrizeList() }, components: { BigTurntable }, computed: { ...mapGetters({ prizeList: 'lottery/prizeList', lotteryResult: 'lottery/lotteryResult' }) }, methods: { ...mapActions({ getPrizeList: 'lottery/getPrizeList', lottery: 'lottery/lottery' }) } } </script>
總結(jié)
以上所述是小編給大家介紹的Vue.js實(shí)現(xiàn)大轉(zhuǎn)盤(pán)抽獎(jiǎng)總結(jié)及實(shí)現(xiàn)思路,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
- vue3實(shí)現(xiàn)抽獎(jiǎng)模板設(shè)置
- vue實(shí)現(xiàn)大轉(zhuǎn)盤(pán)抽獎(jiǎng)功能
- Vue組件實(shí)現(xiàn)數(shù)字滾動(dòng)抽獎(jiǎng)效果
- vue實(shí)現(xiàn)宮格輪轉(zhuǎn)抽獎(jiǎng)
- VUE實(shí)現(xiàn)大轉(zhuǎn)盤(pán)抽獎(jiǎng)
- vue簡(jiǎn)單實(shí)現(xiàn)轉(zhuǎn)盤(pán)抽獎(jiǎng)
- vue組件實(shí)現(xiàn)移動(dòng)端九宮格轉(zhuǎn)盤(pán)抽獎(jiǎng)
- 基于VUE實(shí)現(xiàn)的九宮格抽獎(jiǎng)功能
- vue實(shí)現(xiàn)手機(jī)號(hào)碼抽獎(jiǎng)上下滾動(dòng)動(dòng)畫(huà)示例
- vue組件封裝實(shí)現(xiàn)抽獎(jiǎng)隨機(jī)數(shù)
相關(guān)文章
vue中定義全局聲明vscode插件提示找不到問(wèn)題解決
這篇文章主要為大家介紹了vue中定義全局聲明vscode插件提示找不到問(wèn)題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05Vue項(xiàng)目之學(xué)生管理系統(tǒng)實(shí)例詳解
這篇文章主要為大家詳細(xì)介紹了Vue項(xiàng)目之學(xué)生管理系統(tǒng)實(shí)例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-03-03Vue-cli Eslint在vscode里代碼自動(dòng)格式化的方法
本篇文章主要介紹了Vue-cli Eslint在vscode里代碼自動(dòng)格式化的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-02-02Vue.js最佳實(shí)踐(五招助你成為vuejs大師)
這篇文章主要介紹了Vue.js最佳實(shí)踐,本文主要面向?qū)ο笫怯幸欢╲ue.js 編輯經(jīng)驗(yàn)的開(kāi)發(fā)者,需要的朋友可以參考下2018-05-05詳解vue微信網(wǎng)頁(yè)授權(quán)最終解決方案
這篇文章主要介紹了 詳解vue微信網(wǎng)頁(yè)授權(quán)最終解決方案,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-06-06解決vue-element-admin中配置跨域出現(xiàn)的問(wèn)題
這篇文章主要介紹了解決vue-element-admin中配置跨域出現(xiàn)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07解決iview打包時(shí)UglifyJs報(bào)錯(cuò)的問(wèn)題
下面小編就為大家分享一篇解決iview打包時(shí)UglifyJs報(bào)錯(cuò)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03