微信小程序--27(自定义组件4)

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

1、属性绑定

用于父组件向子组件的只当属性设置数据,但只能设置JSON兼容的数据

2、事件绑定

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

3、获取组件实例

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

二、属性绑定

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

示例:

1、先创建一个组件test5,在component文件目录下

2、在wxml文件中进行属性绑定

复制代码
home.wxml文件中,父组件的中count值
<test5 count="{{count}}"></test5>
<view>父组件中,count的值是:{{count}}</view>

//test5.js文件中,指定count的类型
properties:{

count:Number
}

test5.wxml文件中count的值,并实现子组件count值自增

<view>子组件中count的值是:{{count}}</view>
<button bindtap="addcount">+1</button>

test.js文件中,实现自增
methods:{

addcount(){

this.setData({

count:this.properties.count+1
})
}

}

会发现count自增并没有同步到父组件当中,这里我们要用到事件绑定事件。

三、事件绑定

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

使用步骤如下:

  1. 在父组件的js中,定义一个函数,这个函数即将通过自定义事件的形式,传递给子组件
复制代码
   //home.js文件中

   syncCount(e){

   console.log(e)
   })
  1. 在父组件的wxml中,通过自定义时间的形式,将步骤1定义的函数引用,传递给子组件
复制代码
   home.wxml文件中,父组件的中count值
   <test5 count="{{count}}"  bind:sync="syncCount"></test5>
   <view>父组件中,count的值是:{{count}}</view>
  1. 在子组件的js文件中,调用this.triggerEvent('自定义事件的名称',{/*参数对象*/}),将数据发送到父组件
复制代码
   test.js文件中,实现自增,触发自定义事件将数值同步给父组件
   methods:{

   addcount(){

   this.setData({

   count:this.properties.count+1
   })

   this.triggerEvent('sync',{value:this.properties.count})
   }

   }
  1. 在父组件的js中,通过e.detail获取到子组件传递过来的数据
复制代码
   //home.js文件中

   syncCount(e){

   this.setData({
   count:e.detail.value
   })

四、获取组件实例

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

复制代码
home.wxml文件
<test5 count="{{count}}"  bind:sync="syncCount" class="custom"  id="cA"> </test5>
<button bindtap="getChild">获取子组件实例</button>

//home.js文件中
getChild(){

const child = this.selectComponent('custom')
child.setData({count:child.properties.count+1})
child.addCount()
},
相关推荐
2501_915921436 小时前
没有 iOS 源码的前提下如何进行应用混淆,源码混淆失效后的替代
android·ios·小程序·https·uni-app·iphone·webview
计算机毕设指导69 小时前
基于微信小程序的扶贫助农系统【源码文末联系】
java·spring boot·后端·微信小程序·小程序·tomcat·maven
会员源码网10 小时前
最新壁纸头像小程序系统源码 制作头像的软件 头像壁纸软件 带流量主
小程序
2501_9151063210 小时前
Perfdog 成本变高之后,Windows 上还能怎么做 iOS APP 性能测试
android·ios·小程序·https·uni-app·iphone·webview
2501_9151063211 小时前
iOS 安装了证书,HTTPS 还是抓不到
android·网络协议·ios·小程序·https·uni-app·iphone
万岳软件开发小城12 小时前
医院APP/小程序开发实战:基于互联网医院系统源码的完整落地流程
小程序·互联网医院系统源码·医院小程序开发·医院app开发·医院软件开发
小光学长12 小时前
基于微信小程序的评奖评优系统51r12nd0(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·微信小程序·小程序
Jenna的海糖12 小时前
检查微信小程序版本更新,手动更新
微信小程序·小程序
2501_9160074713 小时前
iOS 自动化上架的工具组合,在多平台环境中实现稳定发布
android·运维·ios·小程序·uni-app·自动化·iphone
1024小神13 小时前
uniapp项目中使用vue3和小程序组件父子通信
前端·小程序·uni-app