uniapp에서 돔 높이를 얻는 방법이 부정확합니다.
머리말
uniapp을 사용하여 작은 프로그램을 개발하는 과정에서 DOM 요소의 높이를 구해야 하는 상황에 자주 직면하게 됩니다. 그러나 때로는 uni.createSelectorQuery().select().boundingClientRect()를 통해 얻은 높이가 정확하지 않은 경우가 있습니다. 그렇다면 이러한 상황은 어떻게 발생하게 되었는가? 어떻게 해결하나요? 이 기사에서는 이에 대해 자세히 설명합니다.
문제가 발생했습니다
먼저 문제를 재현해 보겠습니다. 예를 들어 아래의 간단한 템플릿에서는 하위 요소 content
의 높이를 가져와야 합니다. content
的高度。
<template> <view class="container"> <view class="content" ref="content">内容区域</view> </view> </template>
我们可以通过以下方式获取 content
元素的高度:
mounted() { uni.createSelectorQuery().in(this).select('.content').boundingClientRect(rect => { console.log(rect.height) }).exec() }
这样我们就可以在控制台里看到 content
的高度。
但是,当我们给 content
元素加上一些样式,比如:
.content { margin: 10px; padding: 20px; }
再次运行程序,我们会发现控制台输出的高度与我们预期的高度不一致,略小于我们期望的高度。这就是我们经常遇到的“获取 DOM 高度不准确”的问题。
原因分析
那么,问题出现的原因是什么呢?在经过查阅资料后,我们可以得知以下原因:
1.单独使用这个样式会导致高度计算错误,产生白边。
2.这是因为 margin
和 padding
对于元素占据的空间是不一样的,margin
是不占据空间的,而 padding
是占据空间的。
由于 boundingClientRect
受到了 padding
和 border
的影响,而 margin
不受影响,所以在 boundingClientRect
获取的高度时会少去 padding
的高度。
解决方案
既然掌握了问题出现的原因,解决方案也就呼之欲出了。我们可以通过以下方法来解决这个问题:
1.通过 uni.createSelectorQuery().exec()
获取父元素的高度,再通过 getComputedStyle
获取子元素的 padding
和 border
,从而计算出子元素的实际高度。
mounted() { uni.createSelectorQuery().in(this).select('.container').boundingClientRect(rect => { const styles = getComputedStyle(this.$refs.content.$el) const paddingTop = parseInt(styles.paddingTop) const paddingBottom = parseInt(styles.paddingBottom) const borderTop = parseInt(styles.borderTopWidth) const borderBottom = parseInt(styles.borderBottomWidth) console.log(rect.height - paddingTop - paddingBottom - borderTop - borderBottom) }).exec() }
2.通过给子元素和父元素都加上 box-sizing:border-box
样式来解决问题。
.container, .content { box-sizing: border-box; margin: 10px; padding: 20px; }
这里我们需要注意两点:
(1)box-sizing
rrreee
content
요소의 높이를 얻을 수 있습니다. rrreee
그래서 콘솔에서content
의 높이를 볼 수 있습니다. 그러나 content
요소에 다음과 같은 일부 스타일을 추가하면: rrreee
프로그램을 다시 실행하면 콘솔 출력 높이가 예상한 높이와 일치하지 않는다는 것을 알게 됩니다. 우리가 기대했던 것보다 약간 작습니다. 이것이 바로 우리가 자주 접하는 "부정확한 DOM 높이 획득" 문제입니다. 🎜🎜원인 분석🎜🎜그럼 문제의 원인은 무엇일까요? 데이터를 검토한 후 다음과 같은 이유를 알 수 있습니다. 🎜🎜1. 이 스타일만 사용하면 높이 계산 오류가 발생하고 가장자리가 흰색으로 변합니다. 🎜🎜2. 이는margin
과 padding
이 요소에 대해 서로 다른 공간을 차지하는 반면 padding
은 공간을 차지하지 않기 때문입니다. code>는 공간을 차지합니다. 🎜🎜boundingClientRect
는 padding
및 border
의 영향을 받지만 margin
은 영향을 받지 않으므로 boundingClientRect
의 높이는 padding
의 높이보다 작습니다. 🎜🎜Solution🎜🎜문제의 원인을 파악했으므로 이제 해결책이 나올 준비가 되었습니다. 다음 방법을 통해 이 문제를 해결할 수 있습니다. 🎜🎜1 uni.createSelectorQuery().exec()
를 통해 상위 요소의 높이를 가져온 다음 getCompulatedStyle을 통해 하위 요소를 가져옵니다.
padding
및 border
를 사용하여 하위 요소의 실제 높이를 계산합니다. 🎜rrreee🎜2. 하위 요소와 상위 요소 모두에 box-sizing:border-box
스타일을 추가하여 문제를 해결하세요. 🎜rrreee🎜여기서 두 가지 점에 주의해야 합니다. 🎜🎜 (1) 두 요소에 box-sizing
스타일을 추가해야 합니다. 🎜🎜(2) 자식 요소와 부모 요소 사이의 간격이 잘못된 것은 아닌지 주의가 필요합니다. 🎜🎜결론🎜🎜위의 방법을 통해 uniapp에서 DOM을 얻을 때 정확도가 높은 문제를 해결할 수 있습니다. 귀하의 상황에 맞게 선택하여 활용하시기 바랍니다. 이 글이 귀하에게 도움이 되기를 바랍니다. 🎜위 내용은 uniapp에서 돔 높이를 얻는 방법이 부정확합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











기사는 UNI-APP에서 SASS 및 적은 전처리기를 사용하여 설정, 혜택 및 이중 사용을 자세히 설명합니다. 주요 초점은 구성과 장점에 있습니다. [159 자]

이 기사는 Uni-App의 애니메이션 API를 사용하는 방법, 애니메이션, 주요 기능 및 애니메이션 타이밍을 결합하고 제어하는 방법을 작성하고 적용하는 단계를 자세히 설명합니다. character count : 159

이 기사는 장치, 통합, 기능, UI/UX, 성능, 크로스 플랫폼 및 보안 테스트를 포함한 UniAPP 응용 프로그램에 대한 다양한 테스트 유형에 대해 설명합니다. 또한 크로스 플랫폼 호환성을 보장하고 JES와 같은 도구를 권장합니다.

이 기사는 코드 최적화, 리소스 관리 및 코드 분할 및 게으른로드와 같은 기술에 중점을 둔 UNIAPP 패키지 크기를 줄이기위한 전략에 대해 설명합니다.

이 기사는 HBuilderx, WeChat 개발자 도구 및 Chrome Devtools와 같은 도구에 중점을 둔 UniAPP 개발을위한 디버깅 도구 및 모범 사례에 대해 설명합니다.

이 기사에서는 UNI-APP의 API를 사용하여 허가 설정 및 오류 처리를 포함하여 카메라 및 지리적 위치와 같은 장치 기능에 액세스하는 것에 대해 설명합니다. 문자 수 : 158

이 기사는 로컬 데이터 관리를 위해 Uni-App의 스토리지 API (Uni.setStorage, uni.getStorage)를 사용하는 방법을 설명하고 모범 사례, 문제 해결 및 효과적인 사용을위한 제한 사항 및 고려 사항에 대해 설명합니다.

이 기사는 내장 API를 사용하여 UNI-APP의 페이지 탐색 처리, 효율적인 탐색을위한 모범 사례, 페이지 전환을위한 사용자 정의 애니메이션 및 페이지 간 데이터를 전달하는 방법에 대해 설명합니다.
