溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

微信小程序中如何使用css3動(dòng)畫(huà)實(shí)現(xiàn)扭蛋抽獎(jiǎng)機(jī)

發(fā)布時(shí)間:2021-07-05 11:40:32 來(lái)源:億速云 閱讀:530 作者:小新 欄目:web開(kāi)發(fā)

這篇文章主要介紹了微信小程序中如何使用css3動(dòng)畫(huà)實(shí)現(xiàn)扭蛋抽獎(jiǎng)機(jī),具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

效果圖

微信小程序中如何使用css3動(dòng)畫(huà)實(shí)現(xiàn)扭蛋抽獎(jiǎng)機(jī)

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í)!

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI