微信小程序父子组件之间的通信

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

1 属性绑定

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

2 事件绑定

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

3 获取组件实例

父组件还可以通过 this.selectComponent() 获取子组件实例对象

这样就可以直接访问子组件的任意数据和方法

二 属性绑定

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

微信小程序父子组件之间的通信_第1张图片

2 子组件在 properties 节点中声明对应的属性并使用。示例代码如下。

微信小程序父子组件之间的通信_第2张图片

三 事件绑定

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

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

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

3 在子组件的 js 中,通过调用 this.triggerEvent('自定义事件名称', { /* 参数对象 */ }) ,将数据发送到父组件

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

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

微信小程序父子组件之间的通信_第3张图片

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

微信小程序父子组件之间的通信_第4张图片

步骤3:在子组件的 js 中,通过调用 this.triggerEvent(‘自定义事件名称’, { /* 参数对象 */ }) ,将数据发送到父组件。

微信小程序父子组件之间的通信_第5张图片

步骤4:在父组件的 js 中,通过 e.detail 获取到子组件传递过来的数据。

微信小程序父子组件之间的通信_第6张图片

四 获取组件实例

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

微信小程序父子组件之间的通信_第7张图片

你可能感兴趣的:(微信小程序,微信小程序)