Definition
The <img> tag is used to embed an image on a web page.
Example
<img
  width="400"
  height="225"
  src="https://res.cloudinary.com/thewebmaster/image/upload/image/moon-earth.png"
  alt="Moon and Earth"
/>Usage
- The <img>element request an opening tag but not a closing tag.
- The srcattribute is required. The value should be a valid path to an image.
- The altattribute is used for screen readers or as a text replacement should the image not load for any reason.
- To prevent reflow (where the contents of the page load, then move around after rendering to make room for the image), you should add the widthandheightattributes. This is important as Cumulative Layout Shift is now part of Google’s new Page Experience Algorithm.
Attributes
The <img> element supports the Global Attributes, as well as the following:
- alt- The - altattribute specifies the alternative text to be used if the image is not displayed for any reason.- Omitting the - altattribute indicates the image is a key part of the document, but no textual information is available. However, setting- alt=""will indicate that it is not a key part of the document. This is useful for tracking pixels or other images that should not be included for screen readers.- alt=""will also stop visual browsers from displaying a broken link if the image fails to load for any reason.
- crossorigin
The crossorigin attribute allows images from a third-party site (that allows CORS) to be used with <canvas>.
Values can include:
- anonymous
- use-credentials
- height- The - heightattribute specifies the height of the- <img>element in pixels.
- ismap
The ismap attribute is a boolean that specifies an image as a server-side map. This attribute is only permitted where the <img> element is a descendant of an <a> element with a href attribute.
- loading- The - loadingattribute specifies how the browser should load the image. The browser must have JavaScript enabled for this to take effect.- Values can include: - eager- This value loads the image immediately.
- lazy- This value defers the image’s loading until it reaches a certain distance from the viewport. This improves the performance of your web page.
 
- referrerpolicy- The - referrerpolicyattribute specifies the referrer information that you wish to send with the link.- Values can include: - no-referrer
- no-referrer-when-downgrade
- origin
- origin-when-cross-origin
- same-origin
- no-referrer-when-downgrade
- strict-origin-when-cross-origin
- unsafe-url
 
- sizes- The - sizesattribute specifies the image sizes between breakpoints. It is used in combination with a media condition. For example:- <img src="example.jpg" srcset="example.jpg 2000w, example-thumb.jpg 400w, example-medium.jpg 1000w, [email protected] 4000w" sizes="100vw">
- src- The - srcattribute specifies the URL to the image.
- srcset- The - srcsetattribute specifies an URL to an image along with a width descriptor (positive integer followed by- w), or a pixel density descriptor (a number followed by- x). It determines the set of images the browser can choose from with each image being a different size. The width or density descriptor is based upon the image’s real size. For example:- <img src="example.jpg" srcset="example.jpg 2000w, example-thumb.jpg 400w, example-medium.jpg 1000w, [email protected] 4000w" sizes="100vw">
- usemap- The - usemapattribute specifies whether the image is to be used as part of an image map. See- <area>for more details.
- width- The - widthattribute specifies the width of the- <img>element in pixels.
Best Practices
- You should use the - altattribute, so if the image does not display for any reason, a text description of the image is provided. This is especially important for non-visual browsers used by users with visual impairments.- The - altattribute value should adequately describe the contents of the image, for example:- <img width="800" height="450" src="https://res.cloudinary.com/thewebmaster/image/upload/image/moon-earth.png" alt="Moon and Earth displayed in space.">
- The - titleattribute should not be used instead of the- altattribute. Furthermore, duplicating the same description in both attributes may cause screen readers to announce it twice.
- If you wish to caption an image you should use the - <figure>and- <figcaption>elements.
Specification
Browser Support
Desktop
| Chrome | Edge | Firefox | IE | Opera | Safari | 
|---|---|---|---|---|---|
| Yes | Yes | Yes | Yes | Yes | Yes | 
Mobile
| Android Webview | Chrome Android | Firefox Android | Opera Android | iOS Safari | Samsung Internet | 
|---|---|---|---|---|---|
| Yes | Yes | Yes | Yes | Yes | Yes | 
