小程序的一个自定义弹框组件

参考:https://www.cnblogs.com/demodashi/p/9452967.html
效果如图:
在这里插入图片描述
实现过程如下:
1.新建component文件夹存放我们的组件,里边存放的就是我们所用的组件,我们今天要做的事弹出框,新建文件夹popup存放我们的组件模板,点击右键选择新建component,就会自动生成组件的模板wxss、wxml、json、js,如图
在这里插入图片描述
2.组件内容,直接贴出
popup.wxml

<view class="wx-popup" wx:if="{{!flag}}">
  <view class='popup-container'>
    <view class="wx-popup-title">{{title}}</view>
    <view class="popup-content">
      <view class="wx-popup-con {{index==tab?'active':''}}" wx:for="{{content}}" data-item="{{item}}" data-index="{{index}}" bindtap="tochange">{{item.name}}</view>
    </view>
    <view class="wx-popup-btn">
      <text class="btn-no" bindtap='_error'>{{btn_no}}</text>
      <text class="btn-ok" bindtap='_success'>{{btn_ok}}</text>
    </view>
  </view>
</view>

popup.wxss

/* component/popup.wxss */
.wx-popup {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, .5);
}
.popup-container {
  position: absolute;
  left: 50%;
  top: 50%;
 
  width: 80%;
  max-width: 600rpx;
  border: 2rpx solid #ccc;
  border-radius: 10rpx;
  box-sizing: bordre-box;
  transform: translate(-50%, -50%); 
  overflow: hidden;
  background: #fff;
}
.wx-popup-title {
  width: 100%;
  padding: 20rpx;
  text-align: center;
  font-size: 32rpx;
  border-bottom: 2rpx solid #cc0000;
}
.popup-content{
padding: 20rpx 40rpx;
max-height: 600rpx;
overflow: auto;
}
.wx-popup-con {
  margin: 30rpx 10rpx;
  text-align: center;
  padding: 18rpx 20rpx;
  border-radius: 30rpx;
  border: 1rpx solid #cc0000;
  color: #cc0000;
}
.active{
  background-color: #cc0000;
  color: #ffffff;
}
.wx-popup-btn {
  display: flex;
  justify-content: space-around;
  border-top: 1rpx solid #ccc;
}
.wx-popup-btn text {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50%;
  height: 90rpx;
  padding: 20rpx;
}
.btn-ok{
  color: #cc0000;
  border-left: 1rpx solid #ccc;
}

popup.js:

Component({
  options: {
    multipleSlots: true // 在组件定义时的选项中启用多slot支持
  },
  /**
   * 组件的属性列表
   */
  properties: {
    title: {            // 属性名
      type: String,     // 类型(必填),目前接受的类型包括:String, Number, Boolean, Object, Array, null(表示任意类型)
      value: '标题'     // 属性初始值(可选),如果未指定则会根据类型选择一个
    },
    // 弹窗内容 格式[{name:'111'},{name:'222'}]
    content: {
      type: Array,
      value: []
    },
    // 弹窗取消按钮文字
    btn_no: {
      type: String,
      value: '取消'
    },
    // 弹窗确认按钮文字
    btn_ok: {
      type: String,
      value: '确定'
    },
    tab: {
      type: Number,
      value: 0
    },
  },
 
  /**
   * 组件的初始数据
   */
  data: {
    flag: true,
    // tab:-1,
    listItem:{}
  },
  //以下为小程序组件的生命周期(划重点,和页面不同)
  lifetimes: {
    attached: function() {
      console.log('attached',this.data.content)
      // 在组件实例进入页面节点树时执行
    },
    ready() {
      console.log('ready',this.data.content)
    },
    created() {
      console.log('created',this.data.content)
    },
    detached: function() {
      // 在组件实例被从页面节点树移除时执行
    },
    pageLifetimes: {
      show: function () {
        // 页面被展示
        console.log(this.data.content)
      },
      hide: function () {
        // 页面被隐藏
        console.log("页面被隐藏")
      },
      resize: function (size) {
        // 页面尺寸变化
        console.log("页面尺寸变化")
      }
    }
  },
  /**
   * 组件的方法列表
   */
  methods: {
    //隐藏弹框
    hidePopup: function () {
      this.setData({
        flag: !this.data.flag
      })
    },
    //展示弹框
    showPopup () {
      this.setData({
        flag: !this.data.flag
      })
    },
    /*
    * 内部私有方法建议以下划线开头
    * triggerEvent 用于触发事件
    */
    _error () {
      //触发取消回调
      this.triggerEvent("error")
    },
    _success () {
      //触发成功回调
      this.triggerEvent("success",this.data.listItem);
    },
    tochange(e){
      console.log(e.currentTarget.dataset)
      this.setData({tab:e.currentTarget.dataset.index})
      this.data.listItem = e.currentTarget.dataset.item
    }
  }
})

3.模板文件也建好了,在首页用这个组件需要配置一下,首先建一个名为index.json的文件,里边配置"usingComponents",就是需要引入到首页,直接上代码:

{
    "navigationBarTitleText": "商家中心",
    "usingComponents": {
        "popup": "/zh_cjdianc/component/popup/popup"
    }
}

4.完成这些基本上大功告成了,还有最重要的一步也是最后一步,引入到首页,看代码

<!--index.wxml-->
<view class="container">
  <view class="userinfo">
    <button bindtap="showPopup"> 点我 </button>
  </view>
  <popup id='popup'
      title='门店切换' 
      content='{{content}}' 
      btn_no='取消' 
      btn_ok='确定'
      tab="{{tab}}"
      bind:error="_error"  
      bind:success="_success">
  </popup>
</view>

5.配置index.js操作点击事件,这个更简单,上代码

//index.js
//获取应用实例
const app = getApp()
 
Page({
 data: {
      content:[{name:'111'},{name:'222'}],
      tab:0, //默认选中哪一个
  },
  onReady: function () {
    //获得popup组件
    this.popup = this.selectComponent("#popup");
  },
 
  showPopup() {
    this.popup.showPopup();
  },
 
  //取消事件
  _error() {
    console.log('你点击了取消');
    this.popup.hidePopup();
  },
  //确认事件
  _success() {
    console.log('你点击了确定');
    this.popup.hidePopup();
  }
})

到此就结束,一个简单的小插件封装好了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值