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

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

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


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


相关文章
|
2月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
723 1
|
2月前
|
存储 小程序 安全
微信的开发管理都需要配置什么?
【10月更文挑战第17天】微信的开发管理都需要配置什么?
35 0
|
2月前
|
JavaScript 小程序 开发者
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
409 0
|
2月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
633 7
|
2月前
|
小程序 前端开发 测试技术
微信小程序的开发完整流程是什么?
微信小程序的开发完整流程是什么?
129 7
ly~
|
3月前
|
存储 供应链 小程序
除了微信小程序,PHP 还可以用于开发哪些类型的小程序?
除了微信小程序,PHP 还可用于开发多种类型的小程序,包括支付宝小程序、百度智能小程序、抖音小程序、企业内部小程序及行业特定小程序。在电商、生活服务、资讯、工具、娱乐、营销等领域,PHP 能有效管理商品信息、订单处理、支付接口、内容抓取、复杂计算、游戏数据、活动规则等多种业务。同时,在企业内部,PHP 可提升工作效率,实现审批流程、文件共享、生产计划等功能;在医疗和教育等行业,PHP 能管理患者信息、在线问诊、课程资源、成绩查询等重要数据。
ly~
83 6
|
2月前
|
缓存 小程序 索引
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
224 1
|
2月前
|
小程序 前端开发 数据安全/隐私保护
微信小程序全栈开发中的身份认证与授权机制
【10月更文挑战第3天】随着移动互联网的发展,微信小程序凭借便捷的用户体验和强大的社交传播能力,成为企业拓展业务的新渠道。本文探讨了小程序全栈开发中的身份认证与授权机制,包括手机号码验证、微信登录、第三方登录及角色权限控制等方法,并强调了安全性、用户体验和合规性的重要性,帮助开发者更好地理解和应用这一关键技术。
79 5
|
2月前
|
小程序 前端开发 JavaScript
微信小程序全栈开发中的PWA技术应用
【10月更文挑战第3天】微信小程序作为新兴应用形态,凭借便捷体验与社交传播能力,成为企业拓展业务的新渠道。本文探讨了微信小程序全栈开发中的PWA技术应用,包括离线访问、后台运行、桌面图标及原生体验等方面,助力开发者提升小程序性能与用户体验。PWA技术在不同平台的兼容性、性能优化及用户体验是实践中需注意的关键点。
68 5
|
2月前
|
小程序 JavaScript API
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
这篇文章介绍了如何在uni-app和微信小程序中实现将图片保存到用户手机相册的功能。
793 0
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机