微信小程序 组件和slot_小程序,自定义组件slot内嵌自定义组件,最里面的自定义组件不能触发事件,如何解决?...

在微信小程序中,当自定义组件通过slot嵌套时,内部组件的事件触发遇到问题。具体表现为最内层的自定义组件无法正常执行事件绑定和triggerEvent。本文探讨了该问题,并寻求可能的解决办法。
摘要由CSDN通过智能技术生成

想要的效果

我的实现

生成时间降序排列

生成时间升序排列

/* index.json */

{

"usingComponents": {

"filter": "../../components/filter/filter",

"filterOption": "../../components/filter-option/filter-option"

}

}

// filter.json & filter-option.json

{

"component": true

}

{{title}}

// filter.js

Component({

options: {

multipleSlots: true // 在组件定义时的选项中启用多slot支持

},

properties: {

title: {

type: String,

value: ''

}

},

data: {

visible: true

},

methods: {

taggle () {

console.log("taggle")

this.setData({

visible: !this.data.visible

})

},

closeFilter () {

this.setData({

visible: false

})

}

},

relations: {

'../filter-option/filter-option': {

type: 'child'

}

}

})

// filter-option.js

Component({

methods: {

onTap () {

console.log("i clicked");

this.triggerEvent('tapoption', {}, {

bubbles: true,

composed: true

});

this.triggerEvent('closefilter')

}

},

relations: {

'../filter/filter': {

type: 'parent'

}

}

})

结果

filter-option的onTap没有起效果,就是console.log也没执行,我怀疑,自定义组件用slot嵌套自定义组件,里面的自定义组件不能绑定事件,更不用谈triggerevent了。

请教

请问有方法实现我要的功能吗?或者是我的用法和理解错了?请指教。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值