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


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中使文本框获得焦点的方法实例分析
Feb 28 Javascript
AngularJS实现表单手动验证和表单自动验证
Dec 09 Javascript
Javascript中Date类型和Math类型详解
Feb 27 Javascript
JavaScript实现Fly Bird小游戏
Dec 15 Javascript
AngularJs表单校验功能实例代码
Feb 09 Javascript
js省市区级联查询(插件版&amp;无插件版)
Mar 21 Javascript
jQuery事件_动力节点Java学院整理
Jul 05 jQuery
webpack多入口文件页面打包配置详解
Jan 09 Javascript
JS实现的自定义map方法示例
May 17 Javascript
微信小程序实现商城倒计时
Nov 01 Javascript
微信小程序之几种常见的弹框提示信息实现详解
Jul 11 Javascript
vue简单练习 桌面时钟的实现代码实例
Sep 19 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下获取上个月、下个月、本月的日期(strtotime,date)
2014/02/02 PHP
PHP获取音频文件的相关信息
2015/06/22 PHP
PHP执行linux命令常用函数汇总
2016/02/02 PHP
php正则表达式验证(邮件地址、Url地址、电话号码、邮政编码)
2016/03/14 PHP
解决在laravel中auth建立时候遇到的问题
2019/10/15 PHP
用js实现的页面关键字密度查询代码
2007/12/27 Javascript
JavaScript入门教程(12) js对象化编程
2009/01/31 Javascript
JavaScript XML操作 封装类
2009/07/01 Javascript
JavaScript实用技巧(一)
2010/08/16 Javascript
javascript设计模式之对象工厂函数与构造函数详解
2015/07/30 Javascript
JS实现图片高斯模糊切换效果的焦点图实例
2017/01/21 Javascript
浅析为什么a=&quot;abc&quot; 不等于 a=new String(&quot;abc&quot;)
2017/10/25 Javascript
详解Require.js与Sea.js的区别
2018/08/05 Javascript
Angular异步变同步处理方法
2018/08/13 Javascript
解决vue 打包发布去#和页面空白的问题
2018/09/04 Javascript
基于js实现判断浏览器类型代码实例
2020/07/17 Javascript
nodejs处理tcp连接的核心流程
2021/02/26 NodeJs
[02:18]DOTA2英雄基础教程 育母蜘蛛
2014/01/20 DOTA
Pyramid添加Middleware的方法实例
2013/11/27 Python
Python中的闭包总结
2014/09/18 Python
Python元组及文件核心对象类型详解
2018/02/11 Python
Linux下多个Python版本安装教程
2018/08/15 Python
python3中datetime库,time库以及pandas中的时间函数区别与详解
2020/04/16 Python
用python实现名片管理系统
2020/06/18 Python
牵手50新加坡:专为黄金岁月的单身人士而设的交友网站
2020/08/16 全球购物
英国银首饰公司:e&e Jewellery
2021/02/11 全球购物
教师求职推荐信范文
2013/11/20 职场文书
书香校园活动方案
2014/02/28 职场文书
党员承诺践诺书
2014/05/20 职场文书
企业领导对照检查材料
2014/08/20 职场文书
教师查摆问题自查报告
2014/10/11 职场文书
2015年个人思想总结
2015/03/09 职场文书
python tkinter实现定时关机
2021/04/21 Python
python opencv旋转图片的使用方法
2021/06/04 Python
mybatis3中@SelectProvider传递参数方式
2021/08/04 Java/Android
Python实战之大鱼吃小鱼游戏的实现
2022/04/01 Python