微信小程序实现底部弹出模态框

网络编程 2021-07-04 14:07www.168986.cn编程入门
这篇文章主要为大家详细介绍了微信小程序实现底部弹出模态框,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了微信小程序实现底部弹出模态框的具体代码,供大家参考,具体内容如下

代码

<view class="modals modals-bottom-dialog" hidden="{{hideModal}}" style="width:100%;height:{{widheight}}px">
 <view class="modals-cancel" bindtap="hideModal"></view>
 <view class="bottom-dialog-body bottom-pos" animation="{{animationData}}">
 <view class="ment_">
  <view></view>
  <view class="ment_num">{{ment.length}}条评论</view>
  <view class="ment_close" bindtap="hideModal">×</view>
 </view>
 <view class="ment_list">
  <view class="ment_li" wx:for="{{ment}}" wx:key="{{index}}">
  <image class="ment_li_img" src="{{item.headpic}}"></image>
  <view class="ment_li_info">
   <view class="ment_li_name">{{item.nickname}}</view>
   <view class="ment_li_content">{{item.memo}}
   <text class="ment_li_date">9-24</text>
   </view>
  </view>
  </view>
 </view>
 <view class="ment_inputbox">
  <input class="ment_input" maxlength="120" adjust-position value="{{mentform}}" bindinput="mentinput" placeholder="有何高见,讲来听听"></input>
  <view class="ment_sendbtn" bindtap="sendment">发送</view>
 </view>
 </view>
</view>

CSS:

/ 评论 /
/模态框/
.modals{
 position:fixed;
 z-index: 100000;
 :0; 
 left: 0; 
 right:0; 
 bottom: 0;
 }
.modals-cancel{
 position:absolute; 
 z-index:1000; 
 :0; 
 left: 0; 
 right:0; 
 bottom: 0; 
 / background-color: rgba(0,0,0,.5); /
 }
.bottom-dialog-body{
 width: 99%;
 margin: 0 auto;
 position:absolute; 
 z-index:10001; 
 bottom:0; 
 left:0; 
 right:0; 
 height:65%; 
 background-color: #fff;
 border--left-radius: 10rpx;
 border--right-radius: 10rpx;
 overflow: hidden;
 display: flex;
 flex-direction: column;
 }
/动画前初始位置/
.bottom-pos{
 -webkit-transform:translateY(100%);
 transform:translateY(100%);
}
.ment_{
 width: 100%;
 display: flex;
 justify-content: space-between;
 align-items: center;
 border-bottom: 1rpx solid #f2f2f2;
 padding: 10rpx 24rpx;
 box-sizing: border-box;
}
.ment_num{
 font-size: 30rpx;
}
.ment_close{
 font-size: 62rpx;
 line-height: 50rpx;
}
.ment_list{
 flex: 1;
 overflow: hidden;
}
.ment_li{
 display: flex;
 padding: 10rpx 24rpx;
 box-sizing: border-box;
}
.ment_li_img{
 width: 40rpx;
 height: 40rpx;
 border-radius: 50%;
 margin-right: 16rpx;
}
.ment_li_info{
 flex: 1;
}
.ment_li_name{
 font-size: 30rpx;
}
.ment_li_content{
 font-size: 28rpx;
}
.ment_li_date{
 color: #999;
 font-size: 24rpx;
 margin-left: 20rpx;
}
.ment_inputbox{
 display: flex;
 padding: 20rpx 24rpx;
 box-sizing: border-box;
 align-items: center;
 justify-content: space-between;
 border-: 1rpx solid #f2f2f2;
}
.ment_input{
 font-size: 30rpx;
 flex: 1;
}
.ment_sendbtn{
 font-size: 30rpx;
 background: #dd5923;
 color: #fff;
 padding: 5rpx 18rpx;
 border-radius: 10rpx;
}

js:

Page({
 data: {
 hideModal: true, //模态框的状态 true-隐藏 false-显示
 animationData: {},
 },
 
 // 显示遮罩层
 showModal: function () {
 var that = this;
 that.setData({
  hideModal: false
 })
 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({
  hideModal: true
  })
 }, 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(),
 })
 },
})

为大家推荐现在关注度比较高的微信小程序教程一篇长沙网络推广为大家精心整理的,希望喜欢。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by