mirror of
https://github.com/withastro/astro.git
synced 2025-01-13 22:11:20 -05:00
* fix: audit incorrectly flagging images as above the fold (#10891) Previously used lement.offsetTop to find the y position of the image, which does not work when the element parent has a position: relative property. Instead, this uses lement.getBoundingClientRect().y top get real y position of the image. There's one issue though, which is that getBoundingClientRect returns the position relative to the user's viewport, not the absolute position. So, add window.scrollY to the value to cancel that effect out, and you have the element's absolute position. https://developer.mozilla.org/en-US/docs/Web/API/Element/getBoundingClientRect https://developer.mozilla.org/en-US/docs/Web/API/Window/scrollY * chore: add changeset
This commit is contained in:
parent
da86d5459f
commit
196092ae69
2 changed files with 9 additions and 2 deletions
5
.changeset/shy-bees-look.md
Normal file
5
.changeset/shy-bees-look.md
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
'astro': patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Fix toolbar audit incorrectly flagging images as above the fold.
|
|
@ -36,7 +36,8 @@ export const perf: AuditRuleWithSelector[] = [
|
||||||
match(element) {
|
match(element) {
|
||||||
const htmlElement = element as HTMLImageElement | HTMLIFrameElement;
|
const htmlElement = element as HTMLImageElement | HTMLIFrameElement;
|
||||||
// Ignore elements that are above the fold, they should be loaded eagerly
|
// Ignore elements that are above the fold, they should be loaded eagerly
|
||||||
if (htmlElement.offsetTop < window.innerHeight) return false;
|
const elementYPosition = htmlElement.getBoundingClientRect().y + window.scrollY
|
||||||
|
if (elementYPosition < window.innerHeight) return false;
|
||||||
|
|
||||||
// Ignore elements using `data:` URI, the `loading` attribute doesn't do anything for these
|
// Ignore elements using `data:` URI, the `loading` attribute doesn't do anything for these
|
||||||
if (htmlElement.src.startsWith('data:')) return false;
|
if (htmlElement.src.startsWith('data:')) return false;
|
||||||
|
@ -54,7 +55,8 @@ export const perf: AuditRuleWithSelector[] = [
|
||||||
const htmlElement = element as HTMLImageElement | HTMLIFrameElement;
|
const htmlElement = element as HTMLImageElement | HTMLIFrameElement;
|
||||||
|
|
||||||
// Ignore elements that are below the fold, they should be loaded lazily
|
// Ignore elements that are below the fold, they should be loaded lazily
|
||||||
if (htmlElement.offsetTop > window.innerHeight) return false;
|
const elementYPosition = htmlElement.getBoundingClientRect().y + window.scrollY
|
||||||
|
if (elementYPosition > window.innerHeight) return false;
|
||||||
|
|
||||||
// Ignore elements using `data:` URI, the `loading` attribute doesn't do anything for these
|
// Ignore elements using `data:` URI, the `loading` attribute doesn't do anything for these
|
||||||
if (htmlElement.src.startsWith('data:')) return false;
|
if (htmlElement.src.startsWith('data:')) return false;
|
||||||
|
|
Loading…
Add table
Reference in a new issue