微信小程序开发入门与实战(三种通信方法)

简介: 微信小程序开发入门与实战(三种通信方法)

自定义组件 - 父子组件之间的通信


1、父子组件之间通信的 3 种方式


① 属性绑定


用于父组件向子组件的指定属性设置数据,仅能设置 JSON 兼容的数据 父 👉 子

② 事件绑定


用于子组件向父组件传递数据,可以传递任意数据 子 👉 父

③ 获取组件实例


父组件还可以通过 this.selectComponent() 获取子组件实例对象 这样就可以直接访问子组件的任意数据和方法 父 👉 子

2、 属性绑定


属性绑定用于实现父向子传值,而且只能传递普通类型的数据,无法将方法传递给子组件。父组件的示例代码

如👇

子组件在 properties 节点中声明对应的属性并使用。

WXML<text4data="{{value}}"></text4><view>-----</view><view>这是父组件的值:{{value}}</view>WXJSdata: {
value:18},
组件jsproperties: {
data:Number},
组件WXML<view>这是子组件的值:{{data}}</view>

3、事件绑定


事件绑定用于实现子向父传值,可以传递任何类型的数据。

使用步骤如 👇

① 在父组件的 js 中,定义一个函数,这个函数即将通过自定义事件的形式,传递给子组件

dataAdd(e){
console.log("我被调用了");
},

② 在父组件的 wxml 中,通过自定义事件的形式,将步骤 1 中定义的函数引用,传递给子组件

<text4data="{{value}}"bind:dataAdd="dataAdd"></text4><view>-----</view><view>这是父组件的值:{{value}}</view>

③ 在子组件的 js 中,通过调用 this.triggerEvent(‘自定义事件名称’, {name:“this.XXX”}) ,将数据发送到父组件

/***组件的方法列表*/methods: {
DataAdd(){
this.setData({
data:this.properties.data+1      }),
this.triggerEvent("dataAdd",{value:this.properties.data})
    }
  },

④ 在父组件的 js 中,通过 e.detail 获取到子组件传递过来的数据

dataAdd(e){
console.log("我被调用了");
console.log(e.detail.value);
this.setData({
value:e.detail.value    })
  },

效果如 👇

1.gif

4、 获取组件实例


可在父组件里调用 this.selectComponent(“id或class选择器”) ,获取子组件的实例对象,从而直接访问子组件的任意数据和方法。调用时需要传入一个选择器,例如 this.selectComponent(“.XXX 或 #XXX”)。

WXML<text4data="{{value}}"bind:dataAdd="dataAdd"class="text4"></text4><view>这是父组件的值:{{value}}</view><buttonstyle="color: red; margin-top: 26rpx;"bindtap="countAdd">父组件按钮</button>WXJS//父组件获取子组件数据并操作子组件countAdd(){
consttext4=this.selectComponent(".text4")
//text4.setData({
//data:text4.properties.data+1// }),
text4.DataAdd()
},

效果如 👇

2.gif

最后


image.png

下篇文章再见ヾ( ̄▽ ̄)ByeBye

image.png


相关文章
|
4天前
|
小程序 前端开发 物联网
无人桌球室小程序平台系统定制开发方案
【项目摘要】随着社会进步和科技发展,无人桌球室小程序应运而生,解决传统桌球室管理难题。提供在线预订、自动计分、赛事查询及会员管理功能,采用微信小程序前端、微服务后端及物联网智能设备技术实现。市场推广结合社交媒体、线下活动及口碑营销。需开发支持,请联系小编。
|
4天前
|
小程序 安全 数据安全/隐私保护
理发店预约小程序开发:随时随地,省时省力
理发店预约小程序开发要点:集成预约系统,用户填写信息并自动匹配时间及理发师;包含充值功能,支持安全支付及多种折扣;用户评价系统确保服务质量透明;发型展示帮助用户选择,支持模拟试戴;重视用户体验,界面友好,加载速度快;确保数据安全,兼容多平台,定期更新以优化性能和响应用户需求。寻求开发合作可联系相关人员。
|
4天前
|
人工智能 小程序 搜索推荐
餐饮类小程序开发定制需要多少钱,费用是怎样的
餐饮小程序开发费用因需求、规模和复杂性而异。基础版约几千到万元,含菜品展示、在线点餐等功能;界面设计费几千到几万;服务器租赁年费几千到几万;维护更新费同水平。总成本通常在几万到几十万之间。选择开发商时要考虑实际需求、合同条款及付款方式。
|
5天前
|
小程序 定位技术
货拉拉货运小程序开发:构建便捷可靠的货运平台
货拉拉货运小程序整合物流服务,用户可录入货物详情、使用地图定位跟踪运输状态;订单管理功能便于查看进度和费用;支持多种支付方式及支付记录查询;评价系统提升服务质量;客服支持确保用户疑问得到解答,打造移动物流新时代。
|
4天前
|
小程序
美团买菜小程序平台开发:搭建便捷的线上买菜渠道
随着时代的发展和人们生活水平的提高,网上购物已经成为更多人的首选。在此背景下,类似美团买菜小程序平台开发应运而生,为消费者提供方便快捷的网上购物体验。下面我们将详细讲解美团买菜小程序平台开发的功能特点和优势。
|
5天前
|
小程序 安全 UED
百果园社区电商小程序开发:打造私域精准营销发展趋势
百果园借助社区电商小程序转型,拓展线上渠道,增强品牌形象,降低运营成本,适应市场变化。小程序提供实时购物、社群互动、商家入驻及优惠活动,强调用户体验、功能丰富性和安全性,成为品牌与消费者连接的新桥梁。
|
5天前
|
小程序 安全 搜索推荐
陪玩交友互动小程序开发:打造有趣的社交互动平台
【陪玩交友小程序】融合趣味与实用,打造安全社交新平台。用户经实名认证后,可享在线匹配、语音聊天、游戏组队等多元互动。智能推荐系统助你高效找到玩伴,共享游戏攻略与娱乐资讯。个性化推荐服务,让每一次交流都充满乐趣,邀请好友共赴精彩社交之旅。
|
3天前
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp的汉服交易小程序的详细设计和实现(源码+lw+部署文档+讲解等)
基于SpringBoot+Vue+uniapp的汉服交易小程序的详细设计和实现(源码+lw+部署文档+讲解等)
17 7
|
3天前
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp的宠物医院微信小程序的详细设计和实现(源码+lw+部署文档+讲解等)
基于SpringBoot+Vue+uniapp的宠物医院微信小程序的详细设计和实现(源码+lw+部署文档+讲解等)
16 7
|
4天前
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp的美食推荐小程序的详细设计和实现(源码+lw+部署文档+讲解等)
基于SpringBoot+Vue+uniapp的美食推荐小程序的详细设计和实现(源码+lw+部署文档+讲解等)