中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

微信小程序實戰之自定義抽屜菜單(7)

發布時間:2020-09-03 08:13:49 來源:腳本之家 閱讀:644 作者:michael_ouyang 欄目:web開發

微信提供了動畫api,就是下面這個

微信小程序實戰之自定義抽屜菜單(7)

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

通過使用這個創建動畫的api,可以做出很多特效出來

下面介紹一個抽屜菜單的案例

實現代碼:
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屬性指定需要執行的動畫--> 
<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){ 
 /* 動畫部分 */ 
 // 第1步:創建動畫實例 
 var animation = wx.createAnimation({ 
  duration: 200, //動畫時長 
  timingFunction: "linear", //線性 
  delay: 0 //0則不延遲 
 }); 
  
 // 第2步:這個動畫實例賦給當前的動畫實例 
 this.animation = animation; 
 
 // 第3步:執行第一組動畫:Y軸偏移240px后(盒子高度是240px),停 
 animation.translateY(240).step(); 
 
 // 第4步:導出動畫對象賦給數據對象儲存 
 this.setData({ 
  animationData: animation.export() 
 }) 
  
 // 第5步:設置定時器到指定時候后,執行第二組動畫 
 setTimeout(function () { 
  // 執行第二組動畫:Y軸不偏移,停 
  animation.translateY(0).step() 
  // 給數據對象儲存的第一組動畫,更替為執行完第二組動畫的動畫對象 
  this.setData({ 
  animationData: animation 
  }) 
  
  //關閉抽屜 
  if (currentStatu == "close") { 
  this.setData( 
   { 
   showModalStatus: false 
   } 
  ); 
  } 
 }.bind(this), 200) 
 
 // 顯示抽屜 
 if (currentStatu == "open") { 
  this.setData( 
  { 
   showModalStatus: true 
  } 
  ); 
 } 
 } 
}) 

微信小程序實戰之自定義抽屜菜單(7)

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

射阳县| 依兰县| 长岭县| 黑龙江省| 新郑市| 吉安市| 稷山县| 米林县| 凤庆县| 莲花县| 新晃| 内江市| 阳原县| 昭平县| 高平市| 湖北省| 墨竹工卡县| 普洱| 南京市| 苍溪县| 临夏市| 岚皋县| 玛沁县| 梧州市| 德阳市| 文登市| 宁陵县| 福建省| 呼玛县| 南投市| 新邵县| 阿尔山市| 得荣县| 湖口县| 巴马| 襄樊市| 民丰县| 鱼台县| 托克托县| 会泽县| 新竹县|