Image width/height from fallback breaks responsive images

Created on 1 April 2025, 1 day ago

Problem/Motivation

Responsive images using srcset and sizes image attributes default to the fallback's image dimensions for the width/height of the <img> tag.

When the width and height of the image defaults to the fallback image dimensions, this overrides any settings in responsive image styles where we provide a set of image styles along with the estimated dimensions images should be rendered at.

The issues the current behavior creates includes rendering images at the wrong size due to the fallback image. I typically select a small-to-medium image as fallback image which is hardly ever the size of the image being rendered.

Steps to reproduce

  1. Use Drupal 10.4+
  2. Create any image styles if necessary or use the existing image styles you may already have
  3. Configure a new Responsive Image Style using Responsive images from the Breakpoints group dropdown
  4. Choose "Select multiple image styles and use the sizes attribute." from the Type fieldset
  5. Select as many image styles as needed
  6. Type the desired sizes value in the Sizes field (i.e. (min-width:768px) 720px, 100vw))
  7. Select a fallback image (preferably an image that is not the size of how you expect your image to render)
  8. Create page where the new responsive image style is used and add images to it. Save it
  9. Your image should render using your fallback image dimensions

See attached screenshot.

Proposed resolution

Restore original responsive image rendering behavior which allowed images to be rendered at the size specified in the Sizes field.

Review this issue https://www.drupal.org/project/drupal/issues/3377420 πŸ› Responsive image width/height values are not used from fallback image style Needs work which seems to be where the new behavior stems from. Perhaps rethink the approach for ensuring the img tag dimensions reflect the correct image's dimensions, not the fallback image.

Remaining tasks

User interface changes

Introduced terminology

API changes

Data model changes

Release notes snippet

πŸ› Bug report
Status

Active

Version

10.4 ✨

Component

responsive_image.module

Created by

πŸ‡ΊπŸ‡ΈUnited States mariohernandez Los Angeles

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Comments & Activities

  • Issue created by @mariohernandez
  • πŸ‡ΊπŸ‡ΈUnited States mariohernandez Los Angeles
  • πŸ‡ΊπŸ‡ΈUnited States mariohernandez Los Angeles
  • πŸ‡ΊπŸ‡ΈUnited States mariohernandez Los Angeles

    I did additional research and testing using vanilla installations of Drupal 10.x.

    First test - Using fallback image width and height

    Expected behavior, image should render large on desktop (max 1290px), and full width on mobile.

    1. First I configured responsive images (resp-img.png)
    2. While inspecting the image, visually it looks tiny and that's because it is using the fallback image dimensions (dimensions.png)
    3. However, looking at the Network tab in the dev tools, we see the right image is loaded, but because Drupal is changing the width and height of the img tag based on the fallback image dimensions (network.png)

    Second test - Not using fallback image

    1. Same responsive image configuration as above
    2. Inspecting the image this time, reveals the right width/height on the image tag which is provided by the Sizes configuration in item #1 above.
    3. The Network tab in inspector's console displays the right image dimensions and visually the image also looks correct (dimensions2.png)

    Conclusion

    Drupal is able to provide the right width and height to the img tag without resourcing to the fallback image. Hoping this can be resolved to be able to effectively use responsive images.

  • πŸ‡ΊπŸ‡ΈUnited States mariohernandez Los Angeles
  • πŸ‡ΊπŸ‡ΈUnited States mariohernandez Los Angeles
  • πŸ‡³πŸ‡ΏNew Zealand quietone

    Changes are made on the main development branch 11.x first, then backported.

  • πŸ‡ΊπŸ‡ΈUnited States mariohernandez Los Angeles
Production build 0.71.5 2024