侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

微信小程序自定义模态弹窗组件详解

微信(小程序)  /  管理员 发布于 3年前   358

小程序自带一个showModal弹窗,调用很简单,但是限制很多,title有字数限制,中间的content也只能放文字不能放组件,所以作为一个前端碰到那种连续好几个跟微信自带的模态弹窗风格一模一样,但是功能又花里胡哨的UI稿,就不能忍受频繁的复制粘贴了。自己写了一个组件,虽然调用起来比微信自带的麻烦一点,但是还蛮实用的。

效果大概长这样。

上代码:

wxml:

  {{title}}   {{content}}      {{cancelText}}  {{confirmText}}  

js:

const regeneratorRuntime = require('../../dependence/generator-runtime.js'); //这是一个es6转es5的jsComponent({ properties: { // 这里定义了innerText属性,属性值可以在组件使用时指定 }, data: { showModal: false, title: '温馨提示', content: '', showCancel: true, cancelColor: '#3a3a3a', cancelText: '取消', confirmColor: '#00800', confirmText: '确认', comfirm() { }, cancel() { } }, methods: { // 外部方法调用 showModal(params) {  this.setData({  showModal: true,  title: params.title || '温馨提示', //title  content: params.content || '',//中间内容  showCancel: params.showCancel == undefined ? true : params.showCancel,//是否显示左侧  cancelColor: params.cancelColor || '#3a3a3a',//取消按钮文字颜色  cancelText: params.cancelText || '取消',//左侧按钮文字  confirmColor: params.confirmColor || '#09BA07',//右侧按钮文字颜色  confirmText: params.confirmText || '确认',//右侧按钮文字  /* 回调函数 */  comfirm: params.comfirm || function(){},//点击确认(右侧按钮)  cancel: params.cancel || function(){}//点击取消(左侧按钮)  }) }, // 点击确定 _comfirm() {  this.setData({  showModal: false  },()=>{  this.data.comfirm();  }) }, // 点击取消 _cancel() {  this.setData({  showModal: false  },()=>{  this.data.cancel();  }) } }}) // 调用示例// 引入组件后通过js selectComponent('#id')方法获得组件对象 再调用组件对象下的showModal方法 传入配置参数即可 可以在组件中自定义内容节点

wxss:

.modalDIY{ position: fixed; z-index: 99999999; top: 0; left: 0; width: 100vw; height: 100vh; background: rgba(0,0,0,0.6); display: flex; align-items: center; align-content: center; justify-content: center;}.bg{ background: #fff; text-align: center; border-radius: 10rpx; width: 90%;}.modalTitle{ padding: 30rpx 40rpx 0 40rpx; font-size: 36rpx; line-height: 55rpx; color: #000;}.modalContent{ padding: 20rpx 40rpx; font-size: 30rpx; color: #7a7a7a;}.modalOperate{ height: 100rpx; line-height: 100rpx; border-top: 2rpx solid #eee; display: flex;}.cancelBtn{ border-right: 2rpx solid #eee; flex: 1;}.comfirmBtn{ flex: 1;}

json:(记住要把component设置成true)

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

调用的时候需要贴别说明一下,拿我上面示例图的第二个弹窗的调用为例

首先引入组件

在wxml中引用组件

在js中可以配置一些颜色之类的样式

首先通过selectComponent这个方法获得组件对象,可以存成全局的常量。

我们要调用这个对象下自己封装的showModal方法

完毕。

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

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

您可能感兴趣的文章:

  • 微信小程序实战之自定义模态弹窗(8)
  • 微信小程序实现自定义modal弹窗封装的方法
  • 微信小程序实现自定义picker选择器弹窗内容
  • 微信小程序实现漂亮的弹窗效果
  • 微信小程序 弹窗自定义实例代码
  • 微信小程序自定义toast弹窗效果的实现代码
  • 微信小程序常用的3种提示弹窗实现详解
  • 微信小程序自定义弹窗实现详解(可通用)
  • 微信小程序表单弹窗实例
  • 微信小程序实现蒙版弹窗效果


  • 上一条:
    微信小程序如何获取地址
    下一条:
    微信小程序实现签字功能
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 小程序开发之跳转微信直播示例api(0个评论)
    • 在uni_app中开发小程序之常用功能示例代码汇总(0个评论)
    • 小程序开发之多端框架:taro(0个评论)
    • 微信小程序前端使用七牛云官方SDK上传七牛云代码示例(0个评论)
    • 百度小程序审核未通过,真机审核存在点击返回键退出小程序...解决方式之一tabBar(0个评论)
    • 近期文章
    • 在laravel框架中的5个HTTP客户端技巧分享(0个评论)
    • 在go语言中使用FFmpeg库实现PCM音频文件编码为mp3格式文件流程步骤(0个评论)
    • gopacket免安装Pcap实现驱动层流量抓包流程步骤(0个评论)
    • 在laravel项目中实现密码强度验证功能推荐扩展包:password-strength(0个评论)
    • 在go语言中用filepath.Match()函数以通配符模式匹配字符串示例(0个评论)
    • Laravel Response Classes 响应类使用优化浅析(0个评论)
    • mysql中sql_mode的各模式浅析(0个评论)
    • 百度文心一言今天发布,个人第一批内测体验记录,不好别打我(0个评论)
    • 嘿加密世界让我们谈谈在共识中将中本聪主流化(0个评论)
    • 在go语言中寻找两个切片或数组中的相同元素/共同点/交集并集示例代码(0个评论)
    • 近期评论
    • 博主 在

      2023年国务院办公厅春节放假通知:1月21日起休7天中评论 @ xiaoB 你只管努力,剩下的叫给天意;天若有情天亦老,..
    • xiaoB 在

      2023年国务院办公厅春节放假通知:1月21日起休7天中评论 会不会春节放假后又阳一次?..
    • BUG4 在

      你翻墙过吗?国内使用vpn翻墙可能会被网警抓,你需了解的事中评论 不是吧?..
    • 博主 在

      go语言+beego框架中获取get,post请求的所有参数中评论 @ t1  直接在router.go文件中配就ok..
    • Jade 在

      如何在MySQL查询中获得当月记录中评论 Dear zongscan.com team, We can skyroc..
    • 2017-10
    • 2018-01
    • 2020-03
    • 2021-06
    • 2021-10
    • 2022-03
    • 2023-02
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客