小程序开发之模态框组件封装


Posted in Javascript onApril 23, 2020

本文实例为大家分享了小程序模态框组件的封装具体代码,供大家参考,具体内容如下

一、前言

对于模态框肯定大家都知道,诸如:Bootstartp、element-ui、layui等等都有自己的弹出层,并可以之定义内容,但是小程序的弹出层原生的太简单,那么我们如果自定义呢?

其实很简单,就是一个遮罩、一个view内容区就搞定了!接下来看一下我自己封装后的模态框效果:

小程序开发之模态框组件封装

感觉还可以哈!

二、模态框组件的使用

1.先在使用页面的json注册该组件

{
 "navigationBarTitleText": "XXXX",
 "usingComponents": {
 "print-popups": "/components/popups/popups"
 }
}

2.使用组件

<view>
 <print-popups ifOpen='{{modelStatus}}' bind:ifClose='closeModel'>
 <view slot='popups_main' class='popups_main'>
 <view class='popups_item'>添加新设备</view>
 <view class='popups_item print_name'>
 <input class='print_input' value='设备1' auto-focus />
 <view class='print_tip'>(点击设备可编辑)</view>
 </view>
 <view class='popups_item print_id'>
 <input placeholder="请输入新添设备ID" />
 <view class='print_id_check'>可用</view>
 </view>
 <button class='popups_item print_btn' type='primary' size='mini'>添加</button>
 </view>
 </print-popups> 
</view>

3.添加隐藏/显示方法

Page({
 /**
 * 页面的初始数据
 */
 data: {
 modelStatus: false
 },
 /**
 * 点击按钮打开模态框
 */
 openModel () {
 const modelStatus = !this.modelStatus
 this.setData({ modelStatus})
 },
 /**
 * 子组件触发的事件
 */ 
 closeModel (event) {
 console.log(event.detail.value)
 this.setData({
 modelStatus: event.detail.value
 })
 }
})

三、模态框组件源码

1.Json文件

{
 "component": true,
 "usingComponents": {}
}

2.wxml文件

需要在阿里图标库找一张close.png的图片。

<!--components/popups/popups.wxml-->
<view wx:if="{{ifOpen}}">
 <view class='popups_shade' bindtap='popupsClose'></view>
 <view class='popups_content'>
 <image src='./images/close.png' class='popups_close' bindtap='popupsClose'></image>
 <slot name='popups_main'/>
 </view>
</view>

3.wxss文件

/* components/popups/popups.wxss */
/* 遮罩 */
.popups_shade {
 width: 100%;
 height: 100%;
 position: fixed;
 top: 0;
 left: 0;
 z-index: 1000;
 background: #000;
 opacity: 0.7;
 overflow: hidden;
}
/* 弹出层内容 */
.popups_content {
 width: 500rpx;
 height: 350rpx;
 overflow: hidden;
 position: fixed;
 top: 0px;
 left: 0px;
 bottom: 0px;
 right: 0px;
 margin: auto;
 z-index: 1001;
 background: #FAFAFA;
 border-radius: 5px;
}
.popups_close {
 width: 30rpx;
 height: 30rpx;
 position: absolute;
 right: 3px;
 top: 3px;
}

4.js文件

// components/popups/popups.js
Component({
 options: {
 multipleSlots: true
 },
 /**
 * 组件的属性列表
 */
 properties: {
 ifOpen: Boolean
 },

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

 /**
 * 父子组件通信
 * 组件的方法列表
 */
 methods: {
 popupsClose () {
 console.log('关闭弹出层' + this.properties.ifOpen)
 this.triggerEvent('ifClose', { value: !this.properties.ifOpen})
 }
 }
})

四、思路

主要是使用slot插槽可以不需要定义内容,可以在使用组件的页面自定义,这样就可以很好提高扩展性!

为大家推荐现在关注度比较高的微信小程序教程一篇:《微信小程序开发教程》小编为大家精心整理的,希望喜欢。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery插件validate验证的小例子
May 08 Javascript
js与jquery获取父元素,删除子元素的两种不同方法
Jan 09 Javascript
JavaScript基础知识学习笔记
Dec 02 Javascript
node.js中的emitter.emit方法使用说明
Dec 10 Javascript
浅谈javascript:两种注释,声明变量,定义函数
Sep 29 Javascript
Bootstrap复选框和单选按钮美化插件(推荐)
Nov 23 Javascript
通过修改360抢票的刷新频率和突破8车次限制实现方法
Jan 04 Javascript
vue实现动态数据绑定
Apr 28 Javascript
关于react-router的几种配置方式详解
Jul 24 Javascript
详解Node.js 中使用 ECDSA 签名遇到的坑
Nov 26 Javascript
puppeteer实现html截图的示例代码
Jan 10 Javascript
谈谈node.js中的模块系统
Sep 01 Javascript
详解Vue3中对VDOM的改进
Apr 23 #Javascript
微信小程序实现滑动操作代码
Apr 23 #Javascript
微信小程序图片右边加两行文字的代码
Apr 23 #Javascript
Vue中通过vue-router实现命名视图的问题
Apr 23 #Javascript
利用原生JS实现欢乐水果机小游戏
Apr 23 #Javascript
JS eval代码快速解密实例解析
Apr 23 #Javascript
浅谈vue权限管理实现及流程
Apr 23 #Javascript
You might like
用PHP动态创建Flash动画
2006/10/09 PHP
PHP+Mysql日期时间如何转换(UNIX时间戳和格式化日期)
2012/07/15 PHP
360通用php防护代码(使用操作详解)
2013/06/18 PHP
Yii2.0高级框架数据库增删改查的一些操作
2015/11/16 PHP
用一段js程序来实现动画功能
2007/03/06 Javascript
Jquery下判断Id是否存在的代码
2011/01/06 Javascript
JS创建自定义表格具体实现
2014/02/11 Javascript
JavaScript使用slice函数获取数组部分元素的方法
2015/04/06 Javascript
图解JavaScript中的this关键字
2020/05/28 Javascript
jQuery中通过ajax调用webservice传递数组参数的问题实例详解
2016/05/20 Javascript
jQuery Select下拉框操作小结(推荐)
2016/07/22 Javascript
微信浏览器禁止页面下拉查看网址实例详解
2017/06/28 Javascript
深入理解Vue2.x的虚拟DOM diff原理
2017/09/27 Javascript
vue中Axios的封装与API接口的管理详解
2018/08/09 Javascript
node.js连接mysql与基本用法示例
2019/01/05 Javascript
小程序实现多列选择器
2019/02/15 Javascript
node.js使用net模块创建服务器和客户端示例【基于TCP协议】
2020/02/14 Javascript
js中火星坐标、百度坐标、WGS84坐标转换实现方法示例
2020/03/02 Javascript
python对url格式解析的方法
2015/05/13 Python
详解Python中break语句的用法
2015/05/14 Python
Python实现PS滤镜的万花筒效果示例
2018/01/23 Python
Python实现合并同一个文件夹下所有PDF文件的方法示例
2018/04/28 Python
浅谈Django中的数据库模型类-models.py(一对一的关系)
2018/05/30 Python
解决tensorflow添加ptb库的问题
2020/02/10 Python
Python内置函数及功能简介汇总
2020/10/13 Python
技术人员面试提纲
2013/11/28 职场文书
如何写自我评价?自我评价写什么好?
2014/03/14 职场文书
大学生精神文明先进个人事迹材料
2014/05/02 职场文书
篝火晚会策划方案
2014/05/16 职场文书
幸福中国演讲稿
2014/09/12 职场文书
某集团股份有限公司委托书样本
2014/09/24 职场文书
英语辞职信怎么写
2015/02/28 职场文书
医院党建工作总结2015
2015/05/26 职场文书
党支部考察意见范文
2015/06/02 职场文书
地道战观后感500字
2015/06/04 职场文书
Nginx四层负载均衡的配置指南
2021/06/11 Servers