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

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

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

小程序自带一个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)
    • 相关文章
    • 2023年9月1日起:微信小程序必须备案才能上线运营(0个评论)
    • 腾讯官方客服回应了:微信好友上限约10000个!(0个评论)
    • 2023年做微信小程序的老铁注意:新增收费项、微信小程序获取手机号也收费了(0个评论)
    • 小程序开发之跳转微信直播示例api(0个评论)
    • 在uni_app中开发小程序之常用功能示例代码汇总(0个评论)
    • 近期文章
    • 适用于 Laravel 的表单请求测试程序包(0个评论)
    • Laravel 10.25版本发布(0个评论)
    • 在go语言中实现生成文件的校验和功能代码示例(0个评论)
    • Laravel 11版本抢先看,看将有什么新功能发布(0个评论)
    • goose数据库迁移工具介绍及使用流程步骤(0个评论)
    • 中国程序员“翻墙”为海外软件公司打工,105.8万工资被罚没!转知乎(0个评论)
    • 在go语言gin框架中使用Sharding(Gorm分表中间件)实现分表流程步骤(0个评论)
    • 在PHP提高性能方式之开启OPCache扩展及OPCache配置参数详解(0个评论)
    • 在js的websocket客户端开发中遇到代码割裂情况解决方案(0个评论)
    • Laravel框架中适用于Eloquent的日期过滤软件包:lara-date-filter(0个评论)
    • 近期评论
    • 路人 在

      php中使用hyperf框架调用讯飞星火大模型实现国内版chatgpt功能示例中评论 教程很详细,如果加个前端chatgpt对话页面就完美了..
    • 博主 在

      科学上网翻墙之v2rayN-Core客户端免费公益节点使用教程中评论 @ mashrdn 多切换几个节点测试,免费ssr是没那么稳..
    • mashrdn 在

      科学上网翻墙之v2rayN-Core客户端免费公益节点使用教程中评论 V2rayn免费节点添加上去了,youtobe无法打开网页,是怎么回事..
    • 张伟 在

      科学上网翻墙之v2rayN-Core客户端免费公益节点使用教程中评论 3q!有用,不过免费节点隔天就要去git上复制新的导进去..
    • 博主 在

      科学上网翻墙访问Google , 上外网神器佛跳墙VPN(永久免费)使用流程步骤中评论 该篇教程已不能用了,告知大家,免的老有老铁问我!..
    • 2016-10
    • 2017-10
    • 2018-01
    • 2020-03
    • 2021-06
    • 2021-10
    • 2022-03
    • 2023-02
    • 2023-06
    • 2023-07
    • 2023-08
    Top

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

    侯体宗的博客