在uni-app x 自定义组件的 mounted 函数执行时,通过 refs 获取元素,再通过getBoundingClientRect获取长宽,得到是的 NAN,是因为此时元素还没渲染吗? 那组件初次渲染完成有对应的生命周期或者其他代替方案吗?
data:image/s3,"s3://crabby-images/50c13/50c1318a324de694114506b2c4173ad986ad3b49" alt="h***@geely.com"
- 发布:2024-01-03 09:29
- 更新:2024-01-03 14:34
- 阅读:405
data:image/s3,"s3://crabby-images/ff4cc/ff4ccc45d6eaedbcb0368ed10fc263d8e69c7fef" alt="爱豆豆"
data:image/s3,"s3://crabby-images/328c0/328c04e1c5960555bf2d7e84aa08f73990981cb2" alt=""
data:image/s3,"s3://crabby-images/d0ea1/d0ea11f9ea353d81974721319180ed865cca9f47" alt=""
爱豆豆 - 办法总比困难多
可以用onReady 和 uni.getElementById 来获取长宽
参考下面的代码片段
DOM参考文档:https://doc.dcloud.net.cn/uni-app-x/dom/#getdomnode
<template>
<view>
<view id="viewId">
<text>11111</text>
</view>
</view>
</template>
<script lang="uts">
export default {
onReady() {
const viewDom = uni.getElementById('viewId') as Element
console.log(viewDom.offsetHeight)
console.log(viewDom.offsetWidth)
}
}
</script>
data:image/s3,"s3://crabby-images/aeb7d/aeb7d9ba131acb694a622583b9e4dbe0ba664100" alt="YUANRJ"
提供以下方案任选其一:
- 使用 uni.createSelectorQuery() 获取
- 使用 onReady 生命周期 (仅页面)
-
h***@geely.com (作者)
感谢!不过onReady 不是页面的生命周期吗? 我在组件里面使用并没有执行。uni.createSelectorQuery() 可行!
2024-01-03 14:23
-
爱豆豆
2024-01-03 11:31