小程序封装自定义组件及父子组件之间的通信

编写子组件(以弹出框为例)

xml

<view class="popbg" wx:if="{{showPop}}">
  <text>{{popText}}</text>
</view>

css:

.popbg{
  width: calc(80% - 2rem);
  margin: 2rem 10% 0;
  padding: 0.7rem 1rem;
  background: #fff;
  border: 1px solid rgb(0,255,0);
  text-align: center;
  border-radius: 10rpx;
  position: fixed;
  top: 0;  
  left: 0;
  z-index: 100000;
}
.popbg text{
  color:  rgb(15, 161, 40);
}

在该页面的json文件中加入以下配置

{
  "component":true 
}

编辑组件的js部分

Component({
  options: {
    multipleSlots: true // 在组件定义时的选项中启用多slot支持 
  }, 
  /**
 - 页面的初始数据
   */
  data: {
    showPop:true
  },
  properties: {
    popText: { 
      type: String,  
      value: '组件默认内容'  
    },
  }, 
  /**
 - 在组件实例进入页面节点树时执行
   */
  attached() {
    var _this = this;
    console.log(1111)
    setTimeout(function () {
      _this.setData({ showPop: false })
      _this.handleClose()
    }, 1000)
  },
  methods:{
    handleClose(){
      console.log("处理关闭内容")
      var showStatus={msg:'已成功关闭'}
      this.triggerEvent('myevent', showStatus)
    }
  }
  
})

子组件编写好之后引入父组件

编写父组件

首先在json中注册

{
  "usingComponents": {
    "pop": "../components/pop/infoShow"
  }
}

一个页面中可以引入多个自定义组件 写法如下:
“usingComponents”: {
“pop”: “…/components/pop/infoShow”,
“alert”: “…/components/alert/alert”
}
也可以注册全局组件,在app.json中
“usingComponents”: {
“pop”: “…/components/pop/infoShow”
}

在xml文件中引入

<view class="container"> 
  <button type="primary" catchtap="clikShowPop">点击</button>
  <text style="margin-top:3rem;color:red" wx:if="{{showTips}}">{{childMsg}}</text>
  <pop id="popInfo" bind:myevent="showStatus" wx:if="{{showPop}}" popText="{{infoMsg}}"></pop>
</view>

父组件js部分:

Page({
  data: {   
    infoMsg:'',
    popInfo:'',
    showPop:false,
    showTips:false,
    childMsg:''
  },
  //点击按钮事件
  clikShowPop(){
    this.setData({
      showPop: true,
      infoMsg:'点击成功',
    })
  },
  //弹框消失时触发父组件的事件
  showStatus(e){
    // console.log(JSON.stringify(e))
    this.setData({
      showTips:true,
      childMsg: e.detail.msg  //接受子组件传递的参数时要用e.detail去接收
    })
  },
 
  onLoad() {
    this.popInfo = this.selectComponent('#popInfo')   //获取组件对象,调用子组件内部函数时就可以用this.popInfo.handleClose()去调用了
  }  
})

至此一个简单的自定义组件就封装好了

关于自定义组件的注意事项:

  • Component 普通页面部分为Page 自定义组件中为Component
  • options
  • data:为子组件中的常量 可以由父组件中this.selectComponent(’#popInfo’)…setData({ showPop: false })来控制
  • properties 为父组件向子组件传的值
  • attached 为生命周期函数
  • methods 为子组件中封装的函数
    子组件可以调用this.triggerEvent(‘myevent’, data)来触发父组件的函数,类似于vue中的this.$emit(‘myevents’,data),data为传递的数据 。父子间通过bind:myevent="showStatus"来绑定函数
    相当于vue中的@myevent=“showStatus”
    关于组件中的生命周期: 在这里插入图片描述
    在这里插入图片描述
    更多详情查看https://developers.weixin.qq.com/miniprogram/dev/framework/custom-component/
    此处不再详细讲述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信小程序是一种基于微信平台的应用程序,它可以在微信中直接运行,无需下载安装。而自定义组件小程序中的一种重要功能,它允许开发者将一些常用的UI元素封装组件,以便在不同的页面中复用。 自定义组件具有以下特点: 1. 组件是由wxml、wxss和js文件组成,可以独立定义样式和逻辑。 2. 组件可以接受外部传入的数据,通过属性进行配置。 3. 组件可以触发事件,向外部传递消息。 4. 组件可以包含子组件,形成组件的嵌套结构。 使用自定义组件的步骤如下: 1. 在小程序项目中创建一个新的文件夹,用于存放自定义组件的相关文件。 2. 在该文件夹中创建一个wxml文件,定义组件的结构。 3. 在同一文件夹中创建一个wxss文件,定义组件的样式。 4. 在同一文件夹中创建一个js文件,定义组件的逻辑。 5. 在需要使用该组件的页面中引入组件,并在wxml中使用组件标签。 例如,我们创建一个名为"custom-component"的自定义组件,其文件结构如下: ``` custom-component/ ├── custom-component.wxml ├── custom-component.wxss └── custom-component.js ``` 在custom-component.wxml中定义组件的结构,例如: ```html <view class="custom-component"> <text>{{text}}</text> <button bindtap="handleClick">点击按钮</button> </view> ``` 在custom-component.wxss中定义组件的样式,例如: ```css .custom-component { background-color: #f5f5f5; padding: 10px; } ``` 在custom-component.js中定义组件的逻辑,例如: ```javascript Component({ properties: { text: { type: String, value: '默认文本' } }, methods: { handleClick() { this.triggerEvent('click', { message: '按钮被点击了' }); } } }) ``` 在需要使用该组件的页面中引入组件,并在wxml中使用组件标签,例如: ```html <custom-component text="Hello World" bind:click="handleCustomComponentClick"></custom-component> ``` 以上就是微信小程序自定义组件的简单介绍。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值