您好,登錄后才能下訂單哦!
這篇文章主要介紹了微信小程序中如何使用css3動(dòng)畫(huà)實(shí)現(xiàn)扭蛋抽獎(jiǎng)機(jī),具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
效果圖
wxml文件:
<view class="ball-box"> <image class="ball ball_1 {{start?'weiyi_1':''}}" src="https://acceleratepic.miniso.com/miniso/ball1.png"></image> <image class="ball ball_2 {{start?'weiyi_2':''}}" src="https://acceleratepic.miniso.com/miniso/ball1.png"></image> <image class="ball ball_3 {{start?'weiyi_3':''}}" src="https://acceleratepic.miniso.com/miniso/ball2.png"></image> <image class="ball ball_4 {{start?'weiyi_4':''}}" src="https://acceleratepic.miniso.com/miniso/ball2.png"></image> <image class="ball ball_5 {{start?'weiyi_5':''}}" src="https://acceleratepic.miniso.com/miniso/ball1.png"></image> <image class="ball ball_6 {{start?'weiyi_6':''}}" src="https://acceleratepic.miniso.com/miniso/ball2.png"></image> <image class="ball ball_7 {{start?'weiyi_7':''}}" src="https://acceleratepic.miniso.com/miniso/ball3.png"></image> <image class="ball ball_8 {{start?'weiyi_8':''}}" src="https://acceleratepic.miniso.com/miniso/ball3.png"></image> <image class="ball ball_9 {{start?'weiyi_9':''}}" src="https://acceleratepic.miniso.com/miniso/ball3.png"></image> <image class="ball ball_10 {{start?'weiyi_10':''}}" src="https://acceleratepic.miniso.com/miniso/ball4.png"></image> <image class="ball ball_11 {{start?'weiyi_11':''}}" src="https://acceleratepic.miniso.com/miniso/ball4.png"></image> </view>
這個(gè)做得我頭皮發(fā)麻,但是寫(xiě)這篇文章時(shí)突然想到,為啥不用個(gè)for循環(huán)來(lái)做呢?!
<view class="ball-box"> <image wx:for="ballList" wx:for-index="i" class="ball ball_{{i}} {{start?'weiyi_{{i}}':''}}" src="https://acceleratepic.miniso.com/miniso/ball{{i}}.png"></image> </view>
這樣看起來(lái)是不是舒服多了,因?yàn)槭沁@段代碼現(xiàn)場(chǎng)手寫(xiě),如果有啥bug也不好說(shuō)。
wxss文件:
.weiyi_1 { animation: around1 1.5s linear infinite; -webkit-animation: around1 1.5s linear infinite; }
簡(jiǎn)單的動(dòng)畫(huà)
/* 位移 */ @-webkit-keyframes around1 { 0% { -webkit-transform: translate(0rpx, 0rpx) } 20% { -webkit-transform: translate(100rpx, -250rpx) } 40% { -webkit-transform: translate(200rpx, -100rpx) } 60% { -webkit-transform: translate(50rpx, -230rpx) } 80% { -webkit-transform: translate(300rpx, -50rpx) } 100% { -webkit-transform: translate(0, 0) } } @keyframes around1 { 0% { transform: translate(0rpx, 0rpx) } 20% { transform: translate(100rpx, -250rpx) } 40% { transform: translate(200rpx, -100rpx) } 60% { transform: translate(50rpx, -230rpx) } 80% { transform: translate(300rpx, -50rpx) } 100% { transform: translate(0, 0) } }
簡(jiǎn)單的位移
其他就不一一列出來(lái)了,反正都差不多,改變一下運(yùn)動(dòng)軌跡就行了。
js文件:
相比喪病的樣式,js文件就簡(jiǎn)單多了。
_this.setData({ start: true })
控制抽獎(jiǎng)開(kāi)始
setTimeout(() => { _this.setData({ start: false, end: true }) //其他代碼部分 //time是接口請(qǐng)求開(kāi)始到結(jié)束的時(shí)間 }, Math.ceil(time / 1500) * 1500 - time)
這里用了一個(gè)setTimeout,用于設(shè)置動(dòng)畫(huà)結(jié)束時(shí)間,優(yōu)化一下動(dòng)畫(huà),不讓結(jié)束看起來(lái)太突兀。
1500是wxss里這是的動(dòng)畫(huà)時(shí)間。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“微信小程序中如何使用css3動(dòng)畫(huà)實(shí)現(xiàn)扭蛋抽獎(jiǎng)機(jī)”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。