【vue3】获取元素高度不准确处理方式

1、在vue3中通过ref=“myDiv”在onMounted获取高度时候出现高度不一致放在nextTick也不行

例如:

onMounted(()=>{
      nextTick(()=>{
      console.log(myDiv.value)
      console.log(myDiv.value.offsetHeight)
      table.divHeight = myDiv.value.offsetHeight - 300
  })
})

在第一个整体输出里的offsetHeight和第二个输出不一致,估计原因是vue3在初始化的时候渲染问题。

2、在div上面加一个key=“index” 在onMounted里面增长强制div更新还是不行,
用v-if通过销毁重新加载组件又会导致mydiv获取不到数据。
也看见有其他的博主用定时器处理感觉效果都不是太好。
解决:
比如我要通过最外面的div计算列表高度,可以先设置一个固定值

  table.divHeight=300
  nextTick(()=>{
    console.log(myDiv.value.offsetHeight)
      table.divHeight = myDiv.value.offsetHeight - 300
  })

我先预设了table列表的高度,nextTick就能够生效获取到外面div的实际高度。

目前问题:在window.onresize测试过程中窗口放大有用,缩小又获取不到外层DIV正确的真实高度了。

尽量用document.body.clientHeight高度作为高度自适应,它在onresize事件基本上都能捕获正确高度,如果监视div很容易出问题。
参考文章:vue3中onMounted获取元素高度不准确

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值