-
Notifications
You must be signed in to change notification settings - Fork 27.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add fallback for <Image /> component when JavaScript is disabled in browser #19052
Merged
+28
−4
Merged
Changes from 11 commits
Commits
Show all changes
17 commits
Select commit
Hold shift + click to select a range
5f177ad
add img fallback when no javascript in browser
brunocrosier 8eaa8b2
formatting
brunocrosier e9135c4
apply styfle fixes
brunocrosier a0ff7ca
remove fragment + use imgStyle
brunocrosier be37666
visibility: 'visible' on <noscript> + styfle fixes
brunocrosier 734f88d
remove ref + add sizes on noscript img
brunocrosier df69386
visibility: 'inherit'
brunocrosier c2a072b
add srcset to noscript img
brunocrosier bb36d83
Merge branch 'canary' into IMAGE_NO_JS_FALLBACK
shuding 88e183b
generate imageAttributes on noscript img
brunocrosier 9365e04
Merge branch 'canary' into IMAGE_NO_JS_FALLBACK
Timer 9e37d4c
update tests
brunocrosier 201bfb5
update test
brunocrosier 78246b9
update test
brunocrosier b54cd22
update test
brunocrosier 9c24d3b
only render <noscript> if !isVisible
brunocrosier d7480e1
Merge branch 'canary' into IMAGE_NO_JS_FALLBACK
kodiakhq[bot] File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What if the image wasn't lazy? Would we duplicate the image in this scenario (when there's no JS)?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry, I'm not sure that I understand exactly what you mean. Are you worried about duplicate network requests?
I don't think there is any possibility that the image will show up twice because there is only one
<img>
inside the<noscript>
. Duplicate network requests shouldn't be happening either because JavaScript is either enabled (in which case, the browser does not request thesrc
of theimg
inside of<noscript>
) or disabled.If I've misunderstood the question, could you explain again please (maybe with a small example?)
Thanks!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think @Timer means that when you have both
loading="eager"
and JS disabled,isVisible
will be true when pre-rendering and the originalimg
tag will show the image. This causes 2 images being rendered on the screen.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For example you will see 2 images (overlapped) with this:
To fix I think we can only add this
<noscript>
tag whenisVisible
is false.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks, latest commit only renders the
<noscript>
whenisVisible
is false