微信小程序组件传值图示过程详解

时间:2021-05-18

A是父组件,B是子组件

父传子

<!-- 父组件A wxml --><view> <componentB paramAtoB='{{paramAtoB}}'></componentB></view>

//父组件Ajson (里面不能有注释)

{ "navigationBarTitleText": "父子传值", "usingComponents": { "componentB": "../../components/son/son" }}//父组件A js// view/father/father.jsPage({ /** * 页面的初始数据 */ data: { paramAtoB: "我是A向B传值" }})<!-- 子组件B wxml --><view class="inner"> {{paramAtoB}}</view>//子组件B jsComponent({ //B在这里接收与data类似可以直接在wxml上用 properties: { paramAtoB: { type: String,//类型 value: 'default value'//默认值 } }, data: { }})

//子组件B json

{ "component": true, "usingComponents": {}}

效果

子传父

<!-- 父组件A wxml --><view> <componentB paramAtoB='{{paramAtoB}}' bind:myevent="onMyEvent"></componentB> {{ paramBtoA }}</view>// view/father/father.jsPage({ /** * 页面的初始数据 */ data: { paramAtoB: "我是A向B传值", paramBtoA: 1122 }, onMyEvent: function (e) { //通过事件接收 this.setData({ paramBtoA: e.detail.paramBtoA }) }})

//父组件A json (里面不能有注释)

{ "navigationBarTitleText": "父子传值", "usingComponents": { "componentB": "../../components/son/son" }}<!-- 子组件B wxml --><view class="inner"> {{paramAtoB}} <button bindtap='change'>向A中传入参数</button></view>

(注意:子组件的方法需要写在methods:{}里面)

//子组件B jsComponent({ //B在这里接收与data类似可以直接在wxml上用 properties: { paramAtoB: { type: String,//类型 value: 'default value'//默认值 } }, data: { }, methods: { //触发change事件向A传值 change: function () { this.triggerEvent('myevent', { paramBtoA: "666传值成功" }); } }})

//子组件B json

{ "component": true, "usingComponents": {}}

原先效果

点击按钮之后

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章