欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信小程序?qū)崙?zhàn)之自定義抽屜菜單(7)

 更新時(shí)間:2017年04月18日 10:26:07   作者:michael_ouyang  
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崙?zhàn)之自定義抽屜菜單效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

微信提供了動(dòng)畫(huà)api,就是下面這個(gè)


相關(guān)鏈接:https://mp.weixin.qq.com/debug/wxadoc/dev/api/api-animation.html#wxcreateanimationobject

通過(guò)使用這個(gè)創(chuàng)建動(dòng)畫(huà)的api,可以做出很多特效出來(lái)

下面介紹一個(gè)抽屜菜單的案例

實(shí)現(xiàn)代碼:
wxml:

<!--button--> 
<view class="btn" bindtap="powerDrawer" data-statu="open">button</view> 
<!--mask--> 
<view class="drawer_screen" bindtap="powerDrawer" data-statu="close" wx:if="{{showModalStatus}}"></view> 
<!--content--> 
<!--使用animation屬性指定需要執(zhí)行的動(dòng)畫(huà)--> 
<view animation="{{animationData}}" class="drawer_attr_box" wx:if="{{showModalStatus}}"> 
 <!--drawer content--> 
 <view class="drawer_content"> 
 <view class="drawer_title line">菜單1</view> 
 <view class="drawer_title line">菜單2</view> 
 <view class="drawer_title line">菜單3</view> 
 <view class="drawer_title line">菜單4</view> 
 <view class="drawer_title">菜單5</view> 
 </view> 
</view> 

wxss:

/*button*/ 
.btn { 
 width: 80%; 
 padding: 20rpx 0; 
 border-radius: 10rpx; 
 text-align: center; 
 margin: 40rpx 10%; 
 background: #0C1939; 
 color: #fff; 
} 
/*mask*/ 
.drawer_screen { 
 width: 100%; 
 height: 100%; 
 position: fixed; 
 top: 0; 
 left: 0; 
 z-index: 1000; 
 background: #000; 
 opacity: 0.2; 
 overflow: hidden; 
} 
/*content*/ 
.drawer_attr_box { 
 width: 100%; 
 overflow: hidden; 
 position: fixed; 
 bottom: 0; 
 left: 0; 
 z-index: 1001; 
 background: #fff; 
} 
.drawer_content { 
 padding: 20rpx 40rpx; 
 height: 470rpx; 
 overflow-y: scroll; 
} 
.drawer_title{ 
 padding:20rpx; 
 font:42rpx "microsoft yahei"; 
 text-align: center; 
} 
.line{ 
 border-bottom: 1px solid #f8f8f8; 
} 

js:

Page({ 
 data: { 
 showModalStatus: false 
 }, 
 powerDrawer: function (e) { 
 var currentStatu = e.currentTarget.dataset.statu; 
 this.util(currentStatu) 
 }, 
 util: function(currentStatu){ 
 /* 動(dòng)畫(huà)部分 */ 
 // 第1步:創(chuàng)建動(dòng)畫(huà)實(shí)例 
 var animation = wx.createAnimation({ 
  duration: 200, //動(dòng)畫(huà)時(shí)長(zhǎng) 
  timingFunction: "linear", //線性 
  delay: 0 //0則不延遲 
 }); 
  
 // 第2步:這個(gè)動(dòng)畫(huà)實(shí)例賦給當(dāng)前的動(dòng)畫(huà)實(shí)例 
 this.animation = animation; 
 
 // 第3步:執(zhí)行第一組動(dòng)畫(huà):Y軸偏移240px后(盒子高度是240px),停 
 animation.translateY(240).step(); 
 
 // 第4步:導(dǎo)出動(dòng)畫(huà)對(duì)象賦給數(shù)據(jù)對(duì)象儲(chǔ)存 
 this.setData({ 
  animationData: animation.export() 
 }) 
  
 // 第5步:設(shè)置定時(shí)器到指定時(shí)候后,執(zhí)行第二組動(dòng)畫(huà) 
 setTimeout(function () { 
  // 執(zhí)行第二組動(dòng)畫(huà):Y軸不偏移,停 
  animation.translateY(0).step() 
  // 給數(shù)據(jù)對(duì)象儲(chǔ)存的第一組動(dòng)畫(huà),更替為執(zhí)行完第二組動(dòng)畫(huà)的動(dòng)畫(huà)對(duì)象 
  this.setData({ 
  animationData: animation 
  }) 
  
  //關(guān)閉抽屜 
  if (currentStatu == "close") { 
  this.setData( 
   { 
   showModalStatus: false 
   } 
  ); 
  } 
 }.bind(this), 200) 
 
 // 顯示抽屜 
 if (currentStatu == "open") { 
  this.setData( 
  { 
   showModalStatus: true 
  } 
  ); 
 } 
 } 
}) 


以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論