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

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

VUE實現大轉盤抽獎

瀏覽:19日期: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久久,三上悠亚国产精品一区二区三区
午夜久久中文| 亚洲精选久久| 91大神在线观看线路一区| 美女精品一区| 亚洲一区二区三区四区电影| 亚洲欧美日韩国产一区二区| 国产午夜精品一区二区三区欧美| re久久精品视频| 日韩视频一区| 亚洲人成毛片在线播放女女| 日韩欧美另类中文字幕| 在线看片日韩| 亚洲丝袜美腿一区| 亚洲在线久久| 亚洲精品福利| 日韩三级久久| 91精品福利观看| 欧美日韩视频免费看| 美女久久精品| 四虎影视精品| 免费日本视频一区| 国产亚洲精品美女久久| 国产精品1区在线| 亚洲播播91| 视频一区二区三区入口| 欧美久久精品| www.51av欧美视频| 亚洲激情偷拍| 国产图片一区| 性感美女一区二区在线观看| 免费精品视频| 亚洲综合色婷婷在线观看| 国产三级一区| 日韩在线看片| 蜜臀av一区二区三区| 国产精品中文字幕制服诱惑| 日韩av首页| 亚洲三区欧美一区国产二区| 麻豆久久久久久久| 欧美亚洲精品在线| 日本成人在线一区| 国产suv精品一区| 免费黄色成人| 日韩av一级片| 欧美日韩国产观看视频| 在线午夜精品| 午夜久久av| 免费在线小视频| 亚洲美女91| 精品国产乱码久久久| 亚洲激情中文| 国产精品久久久久久妇女| 久久久影院免费| 日韩综合小视频| 日韩国产一区二区三区| 日本一区福利在线| 成人va天堂| 青青草91视频| 亚洲高清毛片| 国产精品亚洲欧美一级在线| 欧美日韩色图| 日本天堂一区| 久久视频国产| 你懂的亚洲视频| 亚洲一区日本| 国产一区二区精品福利地址| 亚洲欧美高清| 高潮久久久久久久久久久久久久| 久久高清一区| 91嫩草亚洲精品| 日韩精品中文字幕一区二区| 亚洲深夜视频| 国产精品a久久久久| 爽爽淫人综合网网站| 日韩精品电影| 日韩和欧美的一区| 久久中文字幕av| 久久免费福利| 日韩国产欧美在线播放| 黄色日韩精品| 亚洲性色av| 精品一二三区| 日本视频在线一区| 亚洲欧美日本日韩| 日韩在线免费| 久久亚州av| 国产日韩欧美中文在线| 蜜臀精品久久久久久蜜臀| 视频二区不卡| 麻豆精品久久| 日韩av影院| 99视频在线精品国自产拍免费观看| 精品三区视频| 欧美另类中文字幕| 亚洲精品乱码久久久久久蜜桃麻豆 | 国产欧美三级| 男人操女人的视频在线观看欧美| 91精品亚洲| av中文资源在线资源免费观看| 国产欧美69| 欧美亚洲色图校园春色| 色狠狠一区二区三区| 亚洲专区一区| 国产高清一区| 波多野结衣久久精品| 老司机精品在线| 国产精品tv| 国产精品久久久久久久久久白浆| 日本亚洲三级在线| 免费精品视频在线| 亚洲国产不卡| 欧美福利一区| 中文另类视频| 久久久久午夜电影| 色婷婷综合网| 亚洲欧洲高清| 午夜影院一区| 久久夜夜操妹子| 国产 日韩 欧美一区| 国产a亚洲精品| 国产美女高潮在线观看| 成人午夜毛片| 中文字幕在线视频久| 高清av一区| 91欧美国产| www.九色在线| 国产综合色区在线观看| 色爱av综合网| 91精品91| 99国产精品久久久久久久| 狠狠干综合网| 日韩影院精彩在线| 亚洲精品一级| 国产欧美亚洲一区| 国产精品久久久久久久久久妞妞| 国产精品手机在线播放| 久久成人高清| 精品国产乱码久久久久久樱花| 国产白浆在线免费观看| 亚洲精品88| 91精品91| 亚洲一区欧美| 国产欧美日韩影院| 福利欧美精品在线| 欧美 日韩 国产一区二区在线视频| 婷婷色综合网| 亚洲一区二区三区无吗| 91成人精品在线| 九九99久久精品在免费线bt| 国产一区二区三区视频在线| 亚洲精品国产嫩草在线观看| 亚洲精品2区| 日韩精品亚洲专区在线观看| 国产精品久久久久久久久免费高清| 国产一区二区精品久| 国内亚洲精品| 综合色就爱涩涩涩综合婷婷| 国产日韩欧美一区二区三区| 人人草在线视频| 免费看欧美美女黄的网站| 国产精品久久久网站| 亲子伦视频一区二区三区| 视频一区免费在线观看| 欧美激情麻豆| 欧洲亚洲一区二区三区| 亚洲一区激情| 免费视频一区二区三区在线观看| 国产精品精品| 亚洲欧美日韩国产综合精品二区| 久久国产精品色av免费看| 欧美国产美女| 免费观看在线综合色| 国产精品nxnn| 亚洲第一区色| 国产一卡不卡| 亚洲综合电影| 丝袜美腿亚洲一区| 麻豆精品新av中文字幕| 欧美理论视频| 国产毛片久久久| 久久久久免费av| 日本v片在线高清不卡在线观看| 精品国产欧美日韩| 国产亚洲一区在线| 国产精品流白浆在线观看| 久久一级电影| 国产欧美大片| 欧美日韩国产一区精品一区| 国产精品综合| 一区三区视频| 欧美黑人做爰爽爽爽| 午夜欧美精品久久久久久久| 国产美女久久| 国产精品嫩草99av在线| 国产精品三级| 国产一区欧美| 久久午夜影院| 日韩一区精品| 久久精品国产68国产精品亚洲| 国产精品国码视频|