小程序弹出层动画

本文介绍了如何在微信小程序中实现底部弹出层的动画效果。通过使用wxml、wxss和js文件,结合微信小程序的动画API,创建了一个包含上滑显示和下滑隐藏的动画效果。当点击按钮时,底部对话框会从底部向上滑动出现;点击遮罩层或再次点击按钮,对话框将沿相反方向下滑隐藏。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

wxml


<view class="modals modals-bottom-dialog" bindtap="hideModal" wx:if="{{value}}">

<view class="modals-cancel" ></view>

<view class="bottom-dialog-body bottom-pos" animation="{{animationData}}"></view>

</view>

<button bindtap="showModal">点我</button>

wxss


/*模态框*/

.modals{position:fixed; z-index: 999; top:0; left: 0; right:0; bottom: 0;}

.modals-cancel{position:absolute; z-index:1000; top:0; left: 0; right:0; bottom: 0; background-color: rgba(0,0,0,.5);}

.bottom-dialog-body{position:absolute; z-index:10001; bottom:0; left:0; right:0; padding:30rpx; height:300rpx; background-color: #fff;}

/*动画前初始位置 !important,千万不要忘记*/

.bottom-pos{-webkit-transform:translateY(100%);transform:translateY(100%);}

js


Page({

data: {

value: false, //模态框的状态 true-隐藏 false-显示

animationData: {},//

},

// 显示遮罩层

showModal: function () {

var that = this;

that.setData({

value: true

})

var animation = wx.createAnimation({

duration: 600,//动画的持续时间 默认400ms 数值越大,动画越慢 数值越小,动画越快

timingFunction: 'ease',//动画的效果 默认值是linear

})

this.animation = animation

setTimeout(function () {

that.fadeIn();//调用显示动画

}, 200)

},

 

// 隐藏遮罩层

hideModal: function () {

var that = this;

var animation = wx.createAnimation({

duration: 800,//动画的持续时间 默认400ms 数值越大,动画越慢 数值越小,动画越快

timingFunction: 'ease',//动画的效果 默认值是linear

})

this.animation = animation

that.fadeDown();//调用隐藏动画

setTimeout(function () {

that.setData({

value: false

})

},

720)//先执行下滑动画,再隐藏模块

 

},

 

//动画集

fadeIn: function () {

this.animation.translateY(0).step()

this.setData({

animationData: this.animation.export()//动画实例的export方法导出动画数据传递给组件的animation属性

})

},

fadeDown: function () {

this.animation.translateY(300).step()

this.setData({

animationData: this.animation.export(),

})

},

})


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值