Company logo
  • Jobs
  • Bootcamp
  • About Us
  • For professionals
    • Home
    • Jobs
    • Courses
    • Questions
    • Teachers
    • Bootcamp
  • For business
    • Home
    • Our process
    • Plans
    • Assessments
    • Payroll
    • Blog
    • Calculator

0

93
Views
Range.getBoundingClientRect() returns invalid value when there is display:content inside the range

Consider following example:

const spacerBefore = document.querySelector(".grid>div:first-child");
const spacerAfter = document.querySelector(".grid>div:last-child");

const rangeBetweenSpacers = document.createRange();
rangeBetweenSpacers.setStartAfter(spacerBefore);
rangeBetweenSpacers.setEndBefore(spacerAfter);

When there are display:content elements between spacerBefore and spacerAfter, then rangeBetweenSpacers.getBoundingClientRect() returns invalid value.

However spacerBefore.getBoundingClientRect() resp spacerAfter.getBoundingClientRect() return correct value.

Is this a bug in browsers (Chromium calculates it wrong, Firefox returns 0), or am I doing something wrong?

document.addEventListener('click', () => {
  alert(`SpacerSeparation using Range: ${rangeBetweenSpacers.getBoundingClientRect().height}`
      + `\nSpacerSeparation using getBoundingClientRect: ${spacerAfter.getBoundingClientRect().top -spacerBefore.getBoundingClientRect().bottom }`);
});


const scrollContainer = document.querySelector(".grid");
const spacerBefore = document.querySelector(".grid>div:first-child");
const spacerAfter = document.querySelector(".grid>div:last-child");

const rangeBetweenSpacers = document.createRange();
rangeBetweenSpacers.setStartAfter(spacerBefore);
rangeBetweenSpacers.setEndBefore(spacerAfter);

scrollContainer.querySelector(".grid-cell").scrollIntoView();
.grid {
    display: grid;
    grid-template-columns: 1fr;
    background: lightblue
}
.grid-row {
    display: contents;
}
.grid-cell {
   background: silver;
   height: 30px;
}
<div class="grid" style="height: 150px; overflow: auto; overflow-anchor: none">
  <div style="height: 10000px;">spacer before</div>
  <div class="grid-row">
    <div class="grid-cell">Row: Click anywhere in the document</div>
  </div>
  <div style="height: 4000px;">spacer after</div>
</div>

7 months ago · Juan Pablo Isaza
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post job Plans Our process Sales
Legal
Terms and conditions Privacy policy
© 2023 PeakU Inc. All Rights Reserved.