日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

VUE實現大轉盤抽獎

瀏覽:21日期:2022-09-29 17:06:31
目錄UI初始參考各值參考圖方案分析-參數配置核心思路:關于旋轉位置參數配置實現邏輯組件使用抽獎效果結語UI

老規矩,先看下靜態UI,以便于有個圖像概念

VUE實現大轉盤抽獎

初始參考各值參考圖

VUE實現大轉盤抽獎

方案分析-參數配置核心思路:

將指針和中獎區域劃分兩部分,目前常規的效果,控制中獎區域旋轉,然后停在指針處,當然控制指針也可以,一套思路,dom結構也比較簡單,唯一算是復雜點的就是中獎區域,但是如果你足夠懶,像我一樣,你可以傳遞一張圖也可以,完全依賴遠端數據;

關于旋轉位置

每個移動位置應均分,360/個數 === 每個獎品所占據的位置,以本文為例8個獎品位置,每個區域應為45deg,每個指針中心位置應為±22.5deg(±的意思看你是順時針還是逆時針)具體值看下面 實現邏輯 區域

參數配置 data 給與組件一些系統參數 旋轉的圈數、效果等等配置 計算屬性 rotateStyle 旋轉角度,實時調整 props 提供組件內部接口的參數和一些核心數據,比如轉盤的圖片等等

// 基礎參數data () { return { isrun: false, rotateAngle: 0, // 旋轉角度 config: { duration: 4000, // 總旋轉時間 ms級 circle: 8, // 旋轉圈數 mode: ’ease-in-out’ // 由快到慢 慣性效果都省了 }, cricleAdd: 1, // 第幾次抽獎 drawIndex: 0 // 中獎索引 轉盤圖片排序 指針右手開始 0-... } } // 計算屬性 computed: { rotateStyle () { const _c = this.config return ` -webkit-transition: transform ${_c.duration}ms ${_c.mode}; transition: transform ${_c.duration}ms ${_c.mode}; -webkit-transform: rotate(${this.rotateAngle}deg); transform: rotate(${this.rotateAngle}deg);` } } // 入參 props: { httpData: {}, // 接口調用所需參數 stateData: { type: Object, default: () => { return { coin: 0, // 超級幣數量 prize_img: ’’ // 轉盤圖片 } } } }實現邏輯 咱們要做的事情很簡單,計算出中獎獎品的位置,輸出即可 位置即對應圈數,drawIndex對應獎品位置,這個參數里面說過了

this.rotateAngle = this.config.circle * 360 * this.cricleAdd - (22.5 + this.drawIndex * 45)// 圈數位置解析// this.config.circle * 360 * this.cricleAdd 順時針總圈數/累積總圈數// 22.5 + this.drawIndex * 45 ===> (獎品位置 === this.drawIndex * 45) (指針中間位置 === 22.5) drawIndex,直接從服務端拿就行了,如果沒有跑出位置,自己可以計算一下 為了方便拓展,拋出了兩個狀態對應抽獎的開始于完成,start和fin

this.$emit(’draw_fin’, ’start’)this.$emit(’draw_fin’, ’fin’) 完整代碼,css就不水字數了,下面附上源碼地址

methods: { async run () {if (this.stateData.coin < 10) { console.log(’超級幣不足’) return} if (this.isrun) return// const data = await this.goDraw()// 可以作為彈窗等信息展示this.$emit(’draw_fin’, ’start’)this.$set(this.stateData, ’coin’, 0) // 更新數據,此處僅為示例,推薦使用 draw_fin方法的 start/fin 進行相應數據更新this.isrun = truethis.rotateAngle = this.config.circle * 360 * this.cricleAdd - (22.5 + this.drawIndex * 45)// 圈數位置解析// this.config.circle * 360 * this.cricleAdd 順時針總圈數/累積總圈數// 22.5 + this.drawIndex * 45 ===> (獎品位置 === this.drawIndex * 45) (指針中間位置 === 22.5) this.cricleAdd++ setTimeout(() => { this.$emit(’draw_fin’, ’fin’) this.isrun = false }, this.config.duration) }, goDraw () { // 請求接口拿到中獎商品 // 加下自己項目的樣式 loading 用戶體驗 return new Promise(async (resolve, reject) => { // await 獎品接口 resolve({msg: ’抽獎明細’ }) }) }組件使用

使用

import dialWrap from ’../../components/dial/dial.vue’<dialWrap ref='dialWrap' :stateData='stateData'></dialWrap>抽獎效果

VUE實現大轉盤抽獎

結語

以上就是大概的實現思路了,比較簡單的效果;再細的一些東西以及拓展,大家可以自行發揮哈~

另附本文-源碼地址,歡迎探討哈~

以上就是VUE實現大轉盤抽獎的詳細內容,更多關于vue 大轉盤抽獎的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美日中文字幕| 日韩av不卡在线观看| 国产日产高清欧美一区二区三区 | 精品国产鲁一鲁****| 国产精品欧美一区二区三区不卡 | 欧美日韩调教| 免费一区二区三区在线视频| 国产经典一区| 国产va免费精品观看精品视频| 精品久久在线| 人人精品亚洲| 欧美日韩国产高清| 在线看片日韩| 国产精区一区二区| 国产一区丝袜| 日韩免费小视频| 伊人久久大香线蕉av不卡| 久久精品av| 蜜桃久久久久久久| 久久国产麻豆精品| av资源中文在线天堂| 99久久亚洲精品蜜臀| 巨乳诱惑日韩免费av| 欧美亚洲tv| 黑森林国产精品av| 午夜亚洲一区| 国产精品欧美在线观看| 午夜欧美巨大性欧美巨大| 国产亚洲激情| 日韩av中文字幕一区二区| 九九久久国产| 久久在线电影| 日日摸夜夜添夜夜添国产精品| 麻豆精品少妇| 欧美91精品| 日韩有吗在线观看| 久久精品国产99国产| 丝袜av一区| 亚洲精品九九| 成人国产精品一区二区网站| 伊人久久亚洲影院| 国产精品一二| 91精品一区国产高清在线gif | 高清日韩欧美| 视频一区二区国产| 精品一区二区三区在线观看视频 | 国产综合欧美| 欧美影院视频| 伊人久久大香线蕉av不卡| 青青国产精品| 99久久婷婷这里只有精品| 欧美一区在线观看视频| www.com.cn成人| 午夜电影一区| 精品亚洲美女网站| 欧美日韩精品一区二区三区在线观看| 蜜桃av.网站在线观看| 日韩一区二区三区高清在线观看| 国产黄大片在线观看| 亚洲久草在线| 青青久久av| 久久av免费| 老色鬼久久亚洲一区二区| av资源中文在线| 国产三级一区| 久久亚洲电影| 国产麻豆久久| 欧美精品影院| 国产视频欧美| 日韩国产在线| 国产精品久久免费视频| 亚洲免费婷婷| 亚洲精品国产嫩草在线观看| 国产精品v一区二区三区| 亚洲欧美日韩一区在线观看| 91欧美日韩| 啪啪亚洲精品| 午夜在线视频观看日韩17c| 日产精品一区二区| 日韩av一区二区三区四区| 亚洲视频综合| а√天堂中文在线资源8| 蜜桃久久精品一区二区| 日韩国产一区二区| 久久一区视频| 69堂免费精品视频在线播放| 亚洲免费一区二区| 亚洲欧美综合| 日本美女一区| 国产精品国产一区| 国产精品视频一区二区三区综合| 免费高清在线一区| 中文一区二区| 久久国产影院| 日韩av一级| 91一区二区三区四区| 国产毛片精品| 亚洲午夜久久| 尹人成人综合网| 久久久久.com| 中文字幕人成乱码在线观看| 麻豆国产欧美一区二区三区| 欧美日韩伊人| 青青青国产精品| 日韩国产欧美三级| 日韩一区免费| 天堂va欧美ⅴa亚洲va一国产| 美女尤物久久精品| 欧美专区在线| 日韩精品一级中文字幕精品视频免费观看 | 欧美天堂亚洲电影院在线观看| 人人草在线视频| 嫩草伊人久久精品少妇av杨幂| 91p九色成人| 欧美久久一区二区三区| 日本久久一区| 国产亚洲一区二区三区啪| 日韩精品亚洲专区在线观看| 亚洲三级视频| 欧美日韩精品一区二区三区视频| 日本国产欧美| 国产精品入口久久| 精品午夜视频| 鲁鲁在线中文| 国产精品蜜芽在线观看| 日产精品一区二区| 人人精品亚洲| 亚洲欧美日韩国产一区二区| 亚洲综合小说| 97久久亚洲| 国产精品2023| 韩日一区二区| 久久九九精品| 六月丁香综合| 91在线成人| 久久精品国产99国产精品| caoporn视频在线| 久久中文亚洲字幕| 亚洲有吗中文字幕| 日韩av一区二区三区四区| 国产精品白浆| www.com.cn成人| 国产亚洲在线观看| 亚洲va久久久噜噜噜久久| 日韩不卡免费视频| 国产在线不卡一区二区三区| 日韩啪啪电影网| 国产精品人人爽人人做我的可爱| 亚洲香蕉视频| 国产精品黄网站| 亚洲黄色免费看| 亚洲永久字幕| 国产欧美精品久久| 日韩欧美一区二区三区免费看| 久久青草久久| 在线精品一区二区| 国产精品久久久久久久久久齐齐 | 亚洲一级特黄| 亚洲综合婷婷| 久久97视频| 日韩欧美少妇| 免费看日韩精品| 精品国产亚洲一区二区三区在线| 日韩欧美少妇| 亚洲小说春色综合另类电影| 欧美激情精品| 国产一区久久| 日本aⅴ亚洲精品中文乱码 | 亚洲精品综合| 国内精品伊人| 午夜在线精品| 久久精品三级| 亚洲一区日韩| 精品深夜福利视频| 好吊一区二区三区| 日本精品国产| 亚洲婷婷在线| 日韩av中文字幕一区二区三区| 精品久久不卡| 男人操女人的视频在线观看欧美| 国产精品**亚洲精品| 91精品成人| 国产欧美成人| 欧美日韩国产高清电影| 国产欧美久久一区二区三区| 亚洲福利一区| 国产精久久久| 蜜桃视频在线观看一区| 天堂av在线| 日韩激情中文字幕| 欧美va天堂在线| 免费看一区二区三区| 欧美日韩国产高清电影| 免费亚洲婷婷| 亚洲一二三区视频| 日韩精品麻豆| 麻豆久久久久久| 午夜久久av| 欧美午夜不卡| 日韩大片免费观看|