微信小程序实现自定义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 相关文章推荐
浅谈tudou土豆网首页图片延迟加载的效果
Jun 23 Javascript
关于IE中getElementsByClassName不能用的问题解决方法
Aug 26 Javascript
JavaScript自定义方法实现trim()、Ltrim()、Rtrim()的功能
Nov 03 Javascript
React组件的三种写法总结
Jan 12 Javascript
bootstrap下拉菜单使用方法解析
Jan 13 Javascript
JavaScript实现向select下拉框中添加和删除元素的方法
Mar 07 Javascript
JavaScript实现的搜索及高亮显示功能示例
Aug 14 Javascript
详解Webpack多环境代码打包的方法
Aug 03 Javascript
vue实现的双向数据绑定操作示例
Dec 04 Javascript
微信小程序设置全局请求URL及封装wx.request请求操作示例
Apr 02 Javascript
vue组件中iview的modal组件爬坑问题之modal的显示与否应该是使用v-show
Apr 12 Javascript
js针对图片加载失败的处理方法分析
Aug 24 Javascript
详解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 判断服务器操作系统的类型
2014/02/17 PHP
php中stream(流)的用法
2014/03/25 PHP
完美的2个php检测字符串是否是utf-8编码函数分享
2014/07/28 PHP
YII中assets的使用示例
2014/07/31 PHP
php实现事件监听与触发的方法
2014/11/21 PHP
PHP数组操作类实例
2015/07/11 PHP
PHP 断点续传实例详解
2017/11/11 PHP
JavaScript 未结束的字符串常量常见解决方法
2010/01/24 Javascript
JS Excel读取和写入操作(模板操作)实现代码
2010/04/11 Javascript
jQuery Pagination Ajax分页插件(分页切换时无刷新与延迟)中文翻译版
2013/01/11 Javascript
引用外部js乱码问题分析及解决方案
2013/04/12 Javascript
jQuery.event兼容各浏览器的event详细解析
2013/12/18 Javascript
jquery操作checkbox示例分享
2014/07/21 Javascript
常用的JS验证和函数汇总
2014/12/23 Javascript
JavaScript控制网页平滑滚动到指定元素位置的方法
2015/04/17 Javascript
js常用正则表达式集锦
2019/05/17 Javascript
详解package.json版本号规则
2019/08/01 Javascript
vue 解决computed修改data数据的问题
2019/11/06 Javascript
ES2020 新特性(种草)
2020/01/12 Javascript
javascript实现前端分页效果
2020/06/24 Javascript
浅谈vue中$bus的使用和涉及到的问题
2020/07/28 Javascript
JS绘图Flot如何实现动态可刷新曲线图
2020/10/16 Javascript
[01:14]DOTA2 7.22版本新增神杖效果展示(智力英雄篇)
2019/05/29 DOTA
Python3遍历目录树实现方法
2015/05/22 Python
Python语言描述最大连续子序列和
2017/12/05 Python
使用卷积神经网络(CNN)做人脸识别的示例代码
2020/03/27 Python
Python 存取npy格式数据实例
2020/07/01 Python
python模块内置属性概念及实例
2021/02/18 Python
使用pandas读取表格数据并进行单行数据拼接的详细教程
2021/03/03 Python
css3 flex实现div内容水平垂直居中的几种方法
2020/03/27 HTML / CSS
惠普加拿大在线商店:HP加拿大
2017/09/15 全球购物
卡骆驰新加坡官网:Crocs新加坡
2018/06/12 全球购物
党员公开承诺书2015
2015/01/21 职场文书
应急管理工作总结2015
2015/05/04 职场文书
导游词之晋城蟒河
2019/12/12 职场文书
类和原型的设计模式之复制与委托差异
2022/07/07 Javascript