微信小程序实现自定义modal弹窗封装的方法


Posted in Javascript onJune 15, 2018

前言

小程序官方提供了 wx.showModal 方法,但样式比较固定,不能满足多元化需求,自定义势在必行~

老规矩先上图

微信小程序实现自定义modal弹窗封装的方法

微信小程序实现自定义modal弹窗封装的方法

点击某个按钮,弹出 modal框,里面的内容可以自定义,可以是简单的文字提示,也可以输入框等复杂布局。操作完点击取消或确定关闭 modal.

如何使用

将下面的 modal.wxml 、modal.wxss 、modal.js 、modal.json 四个文件复制到对应位置即可。

封装完之后调用起来也很简单,看看调用的代码吧

<modal show="{{showModal}}" height='60%' bindcancel="modalCancel" bindconfirm='modalConfirm'>
  <view class='modal-content'> 
  <formrow wx:for='{{goodsList}}' wx:key='{{index}}' title="{{item.name}}" placeholder='库存{{item.store}}' mode='input' rowpadding='10rpx' currentId="{{index}}" bindinput='goodsInput'></formrow>
  </view>
</modal>

在modal中定义了 slot,所以可以将需要展示的任何布局包裹在 modal 中。

上面的代码简化一下就是

<modal show="{{showModal}}" height='60%' bindcancel="modalCancel" bindconfirm='modalConfirm'>
  <view class='modal-content'>你自己的布局</view>
</modal>

需要传四个属性

show :用来控制 modal 的显示隐藏。

height : 定义 modal 的高度,可以是百分比,也可以是具体单位如 600rpx。

bindcancel :点击取消按钮的回调。

bindconfirm :点击确定按钮的回调。

自己的布局用一个 view 包起来放到 modal 标签里即可。

开始封装

首先在你存放自定义组件的文件夹里新建个 modal 文件夹,个人习惯将所有组件都放在 components 下面。

然后右键新建 component,注意是 component 不是 page ,因为要作为组件引入到页面中。

先看布局吧

modal.wxml

<view class='mask' wx:if='{{show}}' bindtap='clickMask'>
 <view class='modal-content' style='height:{{height}}'>
  <scroll-view scroll-y class='main-content'>
   <slot></slot>
  </scroll-view>
  <view class='modal-btn-wrapper'>
   <view class='cancel-btn' style='color:rgba(7,17,27,0.6)' bindtap='cancel'>取消</view>
   <view class='confirm-btn' style='color:#13b5f5' bindtap='confirm'>确定</view>
  </view>
 </view>
</view>

布局讲解

最外层是半透明的 mask 蒙版,覆盖了整个页面。里面是包裹内容的 view ,内容区有两层,上面是放置传入布局的主内容区,下面是取消和确定两个按钮。

这里把 slot 用 scroll-view 包裹了起来,处理了传入的布局高度超出内容区域的问题,如果超出将会滚动。所以不必担心传入的布局高度,大胆用就行。

内容区的高度通过属性传入的 height 确定,默认是 80%

modal.wxss
.mask{
 position: absolute;
 left: 0;
 right: 0;
 top: 0;
 bottom: 0;
 display: flex;
 justify-content: center;
 align-items: center;
 background-color: rgba(0,0,0,0.4);
 z-index: 9999;
}

.modal-content{
 display: flex;
 flex-direction: column;
 width: 90%;
 /* height: 80%; */
 background-color: #fff;
 border-radius: 10rpx;
}

.modal-btn-wrapper{
 display: flex;
 flex-direction: row;
 height: 100rpx;
 line-height: 100rpx;
 border-top: 2rpx solid rgba(7,17,27,0.1);
}

.cancel-btn, .confirm-btn{
 flex: 1;
 height: 100rpx;
 line-height: 100rpx;
 text-align: center;
 font-size: 32rpx;
}

.cancel-btn{
 border-right: 2rpx solid rgba(7,17,27,0.1);
}

.main-content{
 flex: 1;
 height: 100%;
 overflow-y: hidden; 
}

css讲解

css没啥讲的,直接复制过去就行。

注意几个点:

将 .mask 的 z-index 设置的高一些,确保能在所有布局的最上层。

modal.js

/**
 * 自定义modal浮层
 * 使用方法:
 * <modal show="{{showModal}}" height='60%' bindcancel="modalCancel" bindconfirm='modalConfirm'>
   <view>你自己需要展示的内容</view>
 </modal>

 属性说明:
 show: 控制modal显示与隐藏
 height:modal的高度
 bindcancel:点击取消按钮的回调函数
 bindconfirm:点击确定按钮的回调函数

 使用模块:
 场馆 -> 发布 -> 选择使用物品
 */

Component({

 /**
  * 组件的属性列表
  */
 properties: {
  //是否显示modal
  show: {
   type: Boolean,
   value: false
  },
  //modal的高度
  height: {
   type: String,
   value: '80%'
  }
 },

 /**
  * 组件的初始数据
  */
 data: {

 },

 /**
  * 组件的方法列表
  */
 methods: {
  clickMask() {
   // this.setData({show: false})
  },

  cancel() {
   this.setData({ show: false })
   this.triggerEvent('cancel')
  },

  confirm() {
   this.setData({ show: false })
   this.triggerEvent('confirm')
  }
 }
})

Js 代码也很简单,在 properties 中定义两个需传入的属性 show 和 height ,并指定默认值。

在 methods 中写点击取消和确定按钮的回调,点击按钮后先通过 this.setData({ show: false }) 将 modal 隐藏掉,再通过 this.triggerEvent('confirm') 将点击事件传递出去。

modal.json
{
 "component": true,
 "usingComponents": {}
}

json 主要是声明 modal 为组件

结语

以上就是简单的 modal 弹窗封装。如果不想要下面的确定取消两个按钮,内容区的所有内容都要外部传入,可以这样写

<view class='mask' wx:if='{{show}}' bindtap='clickMask'>
  <slot></slot>
</view>

如果需要多个 slot 也可以,小程序都支持。

具体怎么实现看具体的业务需求吧,自定义的组件就是灵活性非常高,可以根据业务需求进行调整。

以上所述是小编给大家介绍的微信小程序实现自定义modal弹窗封装的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript让IE浏览器event对象符合W3C DOM标准
Nov 24 Javascript
js下将阿拉伯数字每三位一逗号分隔(如:15000000转化为15,000,000)
Jun 02 Javascript
javascript转换日期字符串为Date日期对象的方法
Feb 13 Javascript
如何减少浏览器的reflow和repaint
Feb 26 Javascript
jQuery获得document和window对象宽度和高度的方法
Mar 25 Javascript
jquery dataview数据视图插件使用方法
Dec 23 Javascript
layui前段框架日期控件使用方法详解
May 19 Javascript
详解vantUI框架在vue项目中的应用踩坑
Dec 06 Javascript
一秒学会微信小程序制作table表格
Feb 14 Javascript
JavaScript中继承原理与用法实例入门
May 09 Javascript
JavaScript如何实现监听键盘输入和鼠标监点击
Jul 20 Javascript
vue编写简单的购物车功能
Jan 08 Vue.js
详解vue组件开发脚手架
Jun 15 #Javascript
在 vue-cli v3.0 中使用 SCSS/SASS的方法
Jun 14 #Javascript
vue cli 3.0 使用全过程解析
Jun 14 #Javascript
jQuery实现列表的增加和删除功能
Jun 14 #jQuery
vue采用EventBus实现跨组件通信及注意事项小结
Jun 14 #Javascript
JS对象与json字符串相互转换实现方法示例
Jun 14 #Javascript
微信小程序左滑动显示菜单功能的实现
Jun 14 #Javascript
You might like
用PHP+MySql编写聊天室
2006/10/09 PHP
Apache实现Web Server负载均衡详解(不考虑Session版)
2013/07/05 PHP
浅析php中常量,变量的作用域和生存周期
2013/08/10 PHP
PHP读取XML格式文件的方法总结
2017/02/27 PHP
js常用函数 不错
2006/09/08 Javascript
javascript轻量级模板引擎juicer使用指南
2014/06/22 Javascript
jquery动态分页效果堪比时光网
2014/09/25 Javascript
javascript自动生成包含数字与字符的随机字符串
2015/02/09 Javascript
各式各样的导航条效果css3结合jquery代码实现
2016/09/17 Javascript
JavaScript实现图片懒加载(Lazyload)
2016/11/28 Javascript
JQuery 动态生成Table表格实例代码
2016/12/02 Javascript
简单实现JS计算器功能
2016/12/21 Javascript
jQuery实现用户输入自动完成功能
2017/02/13 Javascript
Vue+SpringBoot开发V部落博客管理平台
2017/12/27 Javascript
24个解决实际问题的ES6代码片段(小结)
2020/02/02 Javascript
Python实现定时备份mysql数据库并把备份数据库邮件发送
2018/03/08 Python
matplotlib 输出保存指定尺寸的图片方法
2018/05/24 Python
vue.js实现输入框输入值内容实时响应变化示例
2018/07/07 Python
Python装饰器基础概念与用法详解
2018/12/22 Python
selenium跳过webdriver检测并模拟登录淘宝
2019/06/12 Python
利用Python绘制Jazz网络图的例子
2019/11/21 Python
python爬虫开发之selenium模块详细使用方法与实例全解
2020/03/09 Python
python中前缀运算符 *和 **的用法示例详解
2020/05/28 Python
使用Keras实现Tensor的相乘和相加代码
2020/06/18 Python
Selenium alert 弹窗处理的示例代码
2020/08/06 Python
理肤泉加拿大官网:La Roche-Posay加拿大
2018/07/06 全球购物
Feelunique德国官方网站:欧洲最大的在线美容零售商
2019/07/20 全球购物
Hello Molly美国:女性时尚在线
2019/08/26 全球购物
Huda Beauty官方商店:化妆和美容产品
2020/09/05 全球购物
浙大网新C/C++面试解惑
2015/05/27 面试题
建筑工程技术应届生求职信
2013/11/17 职场文书
医院护士的求职信范文
2013/12/26 职场文书
装饰资料员岗位职责
2013/12/30 职场文书
高三学习决心书
2014/03/11 职场文书
声乐专业大学生职业生涯规划书:理想的未来需要自己去打造
2014/09/20 职场文书
放弃遗产继承公证书
2015/01/26 职场文书