Steven 30.12.2020
The most confusing thing when you inspect responsive images is the fact that the browser takes into account the DPR (Device Pixel Ratio) in order to download the most appropriate image size.
Steven
An excellent article detailing the use of the srcset and sizes attributes is available here
https://developer.mozilla.org/en-US/docs/Learn/HTML/Multimedia_and_embedding/Responsive_images
Find out the Device To Pixel (DPR) of your device by opening up the page inspector (e.g. Chrome Devtools), typing in the console
window.devicePixelRatio
The device pixel ratio is the ratio between physical pixels and logical pixels. For instance, the iPhone 4 and iPhone 4S report a device pixel ratio of 2, because the physical linear resolution is double the logical linear resolution.
Physical resolution: 960 x 640
Logical resolution: 480 x 320
https://stackoverflow.com/questions/8785643/what-exactly-is-device-pixel-ratio#:~:text=The%20device%20pixel%20ratio%20is,double%20the%20logical%20linear%20resolution.&text=Other%20devices%20report%20different%20device,%2C%20including%20non%2Dinteger%20ones.
Below example for standard Bootstrap 5 grid layout and two image sizes ‘full‘ and ‘medium‘. The medium image is displayed in a col-md-4 column
breakpoint | max-width image full | max-width image medium |
---|---|---|
xs (<576px) | 576px | 576px |
sm (≥576px) | 540px | 540px |
md (≥768px) | 720px | 240px |
lg (≥992px) | 960px | 320px |
xl (≥1200px) | 1140px | 380px |
xxl (≥1400px) | 1320px | 440px |
You can fine-tune the above table by also taking into account $grid-gutter-width and any other customizations to the grid layout on your end.
Media settings are available in Settings > Media. A good choice for WordPress default image sizes would be
image format | image size [px] |
---|---|
thumbnail | 380px |
medium | 576px |
medium_large | 960px |
large | 1320px |
You can take control over what image size information is given to the browser.
The sizes attribute tells the browser how much screen width the image will take
Take into account the image size and the responsive breakpoints when you fill in the sizes attribute. The below goes in your functions.php file.
function assistancy_responsive_images( $attr, $attachment, $size ) {
if ( $size == 'full' ) {
$attr['sizes'] = '100vw';
}
else {
// make any customizations based on other image sizes here
$attr['sizes'] = '(min-width: 768px) 440px, 100vw';
// expand to include as many breakpoints as you like. List the larger ones first!
}
return $attr;
}
add_filter( 'wp_get_attachment_image_attributes', 'assistancy_responsive_images', 10, 3 );
Take into account the Device To Pixel ratio of your device when verifying if responsive images are working! Example verification:
Each time you make changes to responsive image formats, a regeneration of thumbnails is needed for all existing media on your website.
The most easy and straightforward way is to get console access to your hosting server. Navigate to the website root (e.g. www/ or public_html/ and let WordPress do the work
# Regenerate all thumbnails, without confirmation.
$ wp media regenerate --yes
In case you have additional image style definitions in your theme or plugin, you can clean them up like this:
// remove any custom image styles
function remove_extra_image_sizes() {
foreach ( get_intermediate_image_sizes() as $size ) {
if ( !in_array( $size, array( 'thumbnail', 'medium', 'medium_large', 'large' ) ) ) {
remove_image_size( $size );
}
}
}
add_action('init', 'remove_extra_image_sizes');
We want to serve appropriate images to all of our users, like small images on slower connections and small screens, and large, high-quality images on fast connections and high-resolution screens. Luckily, all modern browsers support a few nifty HTML features to help us optimize our images for whate…
https://formidable.com/blog/2019/responsive-images/
A very easy way to enforce strong passwords in Wordpress, is to disable the 'confirm weak password' checkbox. On top of this, we optimize the loading of the password strength estimator, zxcvbn.
Bootstrap 5 utilizes both theme-color("primary") and $primary color defintions. This article details how to override and extend the theme-colors using Sass.
Here are the basics to get started with a fully customizable Wordpress theme based on the Bootstrap framework. It uses Yarn as package manager, Esbuild and SASS for JS and SCSS compilation respectively.
Joe barrett
06.10.2023 - 19:41Great help here. I defeated the DPR by using 50vw and now I get the 5kb small on mobile! Thanks for the starter code.
murat
12.11.2021 - 18:29Steven thanks for reply. Ok. I am using this plugin on my site https://wordpress.org/plugins/ewww-image-optimizer/. This plugin also creates webp images. In html, the following code appears.
Manzara In this case, will webp images be included? Thank you for your help.
murat
11.11.2021 - 19:48First of all, thank you for the article. There are only 3 options in the wordpress settings>media section. There are only Thumbnail, medium, large options. There is no medium_large option, which is the 4th option mentioned in your article. ???
Also in this line;
// make any customizations based on other image sizes here
$attr[‘sizes’] = ‘(min-width: 768px) 440px, 100vw’;
please give everything. We are not experts. Please add them all. thanks.
Steven
11.11.2021 - 20:30Hey Murat,
The media section lists only three options, nevertheless WordPress has by default 4 images sizes (medium_large is not listed).
Here is an example srcset configuration that distinguishes between ‘full’ images and everything else:
/* Serve responsive images with the srcset and sizes attributes.
* This function checks the image format requested.
* 'Full' images are served according to Bootstraps maximum container widths at different breakpoints
* Other images are served according to maximum card width at different breakpoints
*/
function assistancy_responsive_images( $attr, $attachment, $size ) {
if ( $size == 'full' ) {
$attr['sizes'] = '(min-width: 1200px) 1140px, (min-width: 992px) 960px, (min-width: 768px) 720px, (min-width: 576px) 540px, 100vw';
}
else {
$attr['sizes'] = '(min-width: 1200px) 380px, (min-width: 992px) 320px, (min-width: 768px) 360px, (min-width: 576px) 270px, 150px';
}
return $attr;
}
add_filter( 'wp_get_attachment_image_attributes', 'assistancy_responsive_images', 10, 3 );