uniapp uni-collapse两层折叠

在网上参考了很多有关的代码都是

this.$nextTick(()=>{
                    this.$nextTick(() => {
                        setTimeout(()=> {
                            this.$refs.xxx.resize();
                        }, 100)
                    })
                })
但是如果第二层中有动态添加或者删除节点时候外层的collapse无法重新计算高度,会导致收缩框添加、删除的部分空白,查看了源码以后发现在uni-collapse-item这个组件中有一个强制更新视图的代码
this.$nextTick(() => {
                this.init(true)
})

由此我发现一旦如要重新计算高度并渲染就需要使用这部分代码,在这个组件中暴露一个方法出来calculateheight(){
                this.$nextTick(() => {
                    setTimeout(()=>{
                        this.init(true)
                    },200)
                })
            },
在使用这个组件的外面用ref去获取这个节点能拿到节点的情况下使用该方法渲染视图即可收缩

这样就可以非常丝滑的动态计算啦!!!!!!!!!!!!!!!!
一个非常坑的地方浪费十几个小时

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值