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

Vue.js實現大轉盤抽獎總結及實現思路

 更新時間:2019年10月09日 09:10:32   作者:碼上組合  
這篇文章主要介紹了 Vue.js實現大轉盤抽獎總結及實現思路,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下

 大家好!先上圖看看本次案例的整體效果。

       實現思路:

Vue component實現大轉盤組件,可以嵌套到任意要使用的頁面。

css3 transform控制大轉盤抽獎過程的動畫效果。

抽獎組件內使用鉤子函數watch監(jiān)聽抽獎結果的返回情況播放大轉盤動畫并給用戶彈出中獎提示。

中獎結果彈窗,為抽獎組件服務。

       實現步驟如下:

 構建api獎品配置信息和抽獎接口,vuex全局存放獎品配置和中獎結果數據信息。

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: '小米平衡車',
    img: 'https://i1.mifile.cn/f/i/g/2015/cn-index/scooter-140!140x140.jpg'
   }, {
    id: 4,
    name: '小米耳機',
    img: 'https://c1.mifile.cn/f/i/g/2015/video/pinpai140!140x140.jpg'
   }
  ]
  return prizeList
 },
 lottery () {
  return {
   id: 4,
   name: '小米耳機',
   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
}

編寫抽獎組件,為保證通用性,組件只負責播放抽獎結果。接收兩個數據和一個方法,如下:

數據一:預置的獎品列表數據(輪播獎品需要)

數據二:抽獎結果,播放抽獎動畫和彈出中獎結果需要

方法:抽獎動作,返回的抽獎結果數據即為數據二,響應式傳遞給組件

大概代碼思路如下(僅供參考,不可運行)

<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 // 默認先旋轉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í)行抽獎動畫
   */
  playWheel (index) {
   
  },
   /**
   * 獲取中獎結果所在獎品列表中的索引,以確定抽獎動畫最終落在哪個獎品
  */
  getPrizeIndex (prizeId) {
  
  }
 },
 watch: {
/**
   * 監(jiān)聽抽獎結果,一旦有中獎信息就開始執(zhí)行抽獎動畫
   */
  lotteryResult (newVal, oldVal) {
   var self = this
   if (newVal.id && newVal.id > 0) {
    let index = self.getPrizeIndex(newVal.id)
    self.playWheel(index)
   }
  }
 }
}
</script>

彈出中獎結果組件,依附于抽獎組件,在上一步的執(zhí)行抽獎結果動畫結束后執(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>

抽獎組件運用在需要使用的頁面中,此頁面需要為抽獎組件提前準備好預置獎品列表和中獎結果信息,并提供好抽獎方法供子組件(抽獎組件)觸發(fā),觸發(fā)完更改抽獎結果響應式傳入到抽獎組件中。

<template>
 <section>
  <div style="width:100%;text-align:center;margin:2rem 0;">您有一次抽獎機會,祝君好運~~~</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>

總結

以上所述是小編給大家介紹的Vue.js實現大轉盤抽獎總結及實現思路,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

相關文章

  • vue組件中的數據傳遞方法

    vue組件中的數據傳遞方法

    這篇文章主要介紹了vue組件中的數據傳遞方法,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧
    2018-05-05
  • vue中定義全局聲明vscode插件提示找不到問題解決

    vue中定義全局聲明vscode插件提示找不到問題解決

    這篇文章主要為大家介紹了vue中定義全局聲明vscode插件提示找不到問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • Vue實現二維碼的展示及下載功能

    Vue實現二維碼的展示及下載功能

    這篇文章主要介紹了Vue實現二維碼的展示及下載功能,其中downloadQRCode()函數中的url為要下載的文件的路徑,本文通過實例代碼給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2024-05-05
  • Vue項目之學生管理系統(tǒng)實例詳解

    Vue項目之學生管理系統(tǒng)實例詳解

    這篇文章主要為大家詳細介紹了Vue項目之學生管理系統(tǒng)實例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • Vue-cli Eslint在vscode里代碼自動格式化的方法

    Vue-cli Eslint在vscode里代碼自動格式化的方法

    本篇文章主要介紹了Vue-cli Eslint在vscode里代碼自動格式化的方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • Vue.js最佳實踐(五招助你成為vuejs大師)

    Vue.js最佳實踐(五招助你成為vuejs大師)

    這篇文章主要介紹了Vue.js最佳實踐,本文主要面向對象是有一定vue.js 編輯經驗的開發(fā)者,需要的朋友可以參考下
    2018-05-05
  • 詳解vue微信網頁授權最終解決方案

    詳解vue微信網頁授權最終解決方案

    這篇文章主要介紹了 詳解vue微信網頁授權最終解決方案,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-06-06
  • 解決vue-element-admin中配置跨域出現的問題

    解決vue-element-admin中配置跨域出現的問題

    這篇文章主要介紹了解決vue-element-admin中配置跨域出現的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • 解決iview打包時UglifyJs報錯的問題

    解決iview打包時UglifyJs報錯的問題

    下面小編就為大家分享一篇解決iview打包時UglifyJs報錯的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • vue路由中前進后退的一些事兒

    vue路由中前進后退的一些事兒

    這篇文章主要給大家介紹了關于vue路由中前進后退的一些事兒,文中通過示例代碼介紹的非常詳細,對大家學習或者使用vue路由具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-05-05

最新評論