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


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 简单应用示例总结
Aug 09 Javascript
setTimeout和setInterval的深入理解
Nov 08 Javascript
jQuery 顶部导航跟随滚动条滚动固定浮动在顶部
Jun 06 Javascript
jQuery实现悬浮在右上角的网页客服效果代码
Oct 24 Javascript
标准的js无缝滚动效果
Aug 30 Javascript
JavaScript学习笔记整理_setTimeout的应用
Sep 19 Javascript
jQuery EasyUI 页面加载等待及页面等待层
Feb 06 Javascript
swiper动态改变滑动内容的实现方法
Jan 17 Javascript
微信小程序实现tab左右切换效果
Nov 15 Javascript
CountUp.js实现数字滚动增值效果
Oct 17 Javascript
详解vue中使用axios对同一个接口连续请求导致返回数据混乱的问题
Nov 06 Javascript
微信小程序基于movable-view实现滑动删除效果
Jan 08 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 缓存实现代码及详细注释
2010/05/16 PHP
PHP中COOKIES使用示例
2015/07/26 PHP
详解PHP防止直接访问.php 文件的实现方法
2017/07/28 PHP
Jsonp 跨域的原理以及Jquery的解决方案
2011/06/27 Javascript
js控制CSS样式属性语法对照表
2012/12/11 Javascript
js显示时间 js显示最后修改时间
2013/01/02 Javascript
在javaScript中关于submit和button的区别介绍
2013/10/20 Javascript
浅谈checkbox的一些操作(实战经验)
2013/11/20 Javascript
JavaScript fontsize方法入门实例(按照指定的尺寸来显示字符串)
2014/10/17 Javascript
一个JavaScript操作元素定位元素的实例
2014/10/29 Javascript
jquery调取json数据实现省市级联的方法
2015/01/29 Javascript
javascript电商网站抢购倒计时效果实现
2015/11/19 Javascript
javascript cookie的简单应用
2016/02/24 Javascript
js阻止浏览器默认行为触发的通用方法(推荐)
2016/05/15 Javascript
js实现简易ATM功能
2020/10/27 Javascript
vue项目页面嵌入代码块vue-prism-editor的实现
2020/10/30 Javascript
JS模拟实现京东快递单号查询
2020/11/30 Javascript
python解析html开发库pyquery使用方法
2014/02/07 Python
Python实现在tkinter中使用matplotlib绘制图形的方法示例
2018/01/18 Python
Python cookbook(数据结构与算法)从序列中移除重复项且保持元素间顺序不变的方法
2018/03/13 Python
python socket网络编程之粘包问题详解
2018/04/28 Python
python3中的md5加密实例
2018/05/29 Python
Python多线程应用于自动化测试操作示例
2018/12/06 Python
pyspark操作MongoDB的方法步骤
2019/01/04 Python
简单了解Django ContentType内置组件
2019/07/23 Python
pytorch 加载(.pth)格式的模型实例
2019/08/20 Python
python 两个数据库postgresql对比
2019/10/21 Python
python代码如何实现余弦相似性计算
2020/02/09 Python
Python集合操作方法详解
2020/02/09 Python
Python matplotlib读取excel数据并用for循环画多个子图subplot操作
2020/07/14 Python
中东奢侈品购物网站:Ounass
2020/09/02 全球购物
大学生自我评价200字(4篇)
2014/09/17 职场文书
2019年销售人员的职业生涯规划书
2019/03/25 职场文书
浅析Python中的随机采样和概率分布
2021/12/06 Python
德劲DE1102数字调谐收音机机评
2022/04/07 无线电
Win11软件图标固定到任务栏
2022/04/19 数码科技