溫馨提示×

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

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

微信小程序?qū)崿F(xiàn)元素漸入漸出動(dòng)畫效果封裝方法

發(fā)布時(shí)間:2020-09-12 10:48:23 來(lái)源:腳本之家 閱讀:324 作者:LYJSpeedX 欄目:web開(kāi)發(fā)

開(kāi)端

之前一直使用堪稱“萬(wàn)能”的jQuery處理用戶交互的動(dòng)畫,近日開(kāi)發(fā)微信小程序,微信小程序高度限制的語(yǔ)法和功能使開(kāi)源函數(shù)可謂對(duì)其“無(wú)能為力”。
那沒(méi)辦法,只好自己寫一個(gè)可以讓元素漸入漸出的,可復(fù)用的函數(shù)了。做到類似jQuery show()的效果

原創(chuàng)文章,允許轉(zhuǎn)載分享。但請(qǐng)轉(zhuǎn)載請(qǐng)一定標(biāo)明出處,這是起碼的尊重
本文章閱讀前需要對(duì)微信小程序的動(dòng)畫api有所了解

先看效果

可以看到,動(dòng)畫效果十分流暢,高度復(fù)用,封裝好后只需要三行代碼實(shí)現(xiàn)動(dòng)畫

微信小程序?qū)崿F(xiàn)元素漸入漸出動(dòng)畫效果封裝方法

解決

1.尋根問(wèn)底,發(fā)現(xiàn)wx_mini_program(下面稱呼微信小程序?yàn)閣xmp [差點(diǎn)叫成 (*´ノ皿`)mmp] )有一個(gè)全局的js邏輯文件,叫app.js,有意思,可以往里面塞自己寫的object(函數(shù)數(shù)據(jù)等等),那就從那里入手吧
2.在app.js中定義全局的動(dòng)畫函數(shù)

App({
 //漸入,漸出實(shí)現(xiàn) 
 show : function(that,param,opacity){
  var animation = wx.createAnimation({
   //持續(xù)時(shí)間800ms
   duration: 800,
   timingFunction: 'ease',
  });
  //var animation = this.animation
  animation.opacity(opacity).step()
  //將param轉(zhuǎn)換為key
  var json = '{"' + param + '":""}'
  json = JSON.parse(json);
  json[param] = animation.export()
  //設(shè)置動(dòng)畫
  that.setData(json)
 },

 //滑動(dòng)漸入漸出
 slideupshow:function(that,param,px,opacity){
  var animation = wx.createAnimation({
   duration: 800,
   timingFunction: 'ease',
  });
  animation.translateY(px).opacity(opacity).step()
  //將param轉(zhuǎn)換為key
  var json = '{"' + param + '":""}'
  json = JSON.parse(json);
  json[param] = animation.export()
  //設(shè)置動(dòng)畫
  that.setData(json)
 },

 //向右滑動(dòng)漸入漸出
 sliderightshow: function (that, param, px, opacity) {
  var animation = wx.createAnimation({
   duration: 800,
   timingFunction: 'ease',
  });
  animation.translateX(px).opacity(opacity).step()
  //將param轉(zhuǎn)換為key
  var json = '{"' + param + '":""}'
  json = JSON.parse(json);
  json[param] = animation.export()
  //設(shè)置動(dòng)畫
  that.setData(json)
 }
})

3.現(xiàn)在我們?cè)倏纯凑{(diào)用這個(gè)函數(shù)的具體方法
在wxml中,只需要設(shè)置animation綁定即可,以首頁(yè)index為例

// 這里是pages/page/index.wxml
//使用view包裹需要?jiǎng)赢嫷脑?//class中定義動(dòng)畫開(kāi)始前的初始樣式,如透明度=0,向下偏移200px等,animtion屬性填入綁定值
<view class="init" animation="{{slide_up1}}">

4.在該頁(yè)的js中

// 這里是pages/page/index.js
//首先獲取小程序?qū)嵗L問(wèn)app.js中的函數(shù)
this.app = getApp();
//調(diào)用show函數(shù),傳參
//注意:查看上面show函數(shù)定義查看參數(shù)含義
//第一個(gè)參數(shù)是當(dāng)前的頁(yè)面對(duì)象,方便函數(shù)setData直接返回?cái)?shù)據(jù)
//第二個(gè)參數(shù)是綁定的數(shù)據(jù)名,傳參給setData,詳細(xì)見(jiàn)上面
//第三個(gè)參數(shù)是上下滑動(dòng)的px,因?yàn)閏lass="init"定義初始該元素向下偏移了200px,所以這里使其上移200px
//第四個(gè)參數(shù)是需要修改為的透明度,這里是1,表示從初始的class="init"中定義的透明度0修改到1
this.app.slideupshow(this, 'slide_up1', -200, 1)

5.讓我們完善流程,達(dá)到預(yù)覽圖首頁(yè)的效果(有延時(shí)的邊上升邊出現(xiàn)效果)
wxml就是將各個(gè)容器分別綁定不同的變量,一個(gè)view容器就是一個(gè)動(dòng)畫單位(可以這樣理解),如

<view class="init" animation="{{slide_up1}}">
  <card>...</card>
</view>
<view class="init" animation="{{slide_up2}}">
  <card>...</card>
</view>

頁(yè)面的js

//onload時(shí)獲取小程序?qū)嵗?onLoad: function (options) {
  this.app = getApp()
 },
//頁(yè)面展示時(shí),觸發(fā)動(dòng)畫
 onShow: function () {
  this.app.slideupshow(this, 'slide_up1', -200, 1)

  setTimeout(function () {
   this.app.slideupshow(this, 'slide_up2', -200, 1)
  }.bind(this), 200);
 },
//頁(yè)面隱藏時(shí),觸發(fā)漸出動(dòng)畫
 onHide: function () {
   //你可以看到,動(dòng)畫參數(shù)的200,0與漸入時(shí)的-200,1剛好是相反的,其實(shí)也就做到了頁(yè)面還原的作用,使頁(yè)面重新打開(kāi)時(shí)重新展示動(dòng)畫
  this.app.slideupshow(this, 'slide_up1', 200, 0)
  //延時(shí)展現(xiàn)容器2,做到瀑布流的效果,見(jiàn)上面預(yù)覽圖
  setTimeout(function () {
   this.app.slideupshow(this, 'slide_up2', 200, 0)
  }.bind(this), 200);
 }

以上所述是小編給大家介紹的微信小程序?qū)崿F(xiàn)元素漸入漸出動(dòng)畫效果封裝方法詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)億速云網(wǎng)站的支持!

向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