このブラウザでは loading 属性が

<img src="/images/sample_01.jpg" width="960" height="593" alt=""> 
<img loading="lazy" class="lazyload" 
     src="" 
     data-src="/images/sample_02.jpg" 
     width="960" height="593" alt=""> 
<img loading="lazy" class="lazyload" 
     src="" 
     data-src="/images/sample_03.jpg" 
     width="960" height="593" alt=""> 
<img loading="lazy" class="lazyload" 
     src="" 
     data-src="/images/sample_04.jpg" 
     width="960" height="593" alt=""> 
<!--  data-src と class="lazyload" の指定なし -->
<img loading="lazy"
     src="/images/sample_05.jpg" 
     width="960" height="593" alt=""> 
<img loading="lazy" class="lazyload" 
     src="" 
     data-src="/images/sample_06.jpg" 
     width="960" height="593" alt=""> 
<img loading="lazy" class="lazyload" 
     src="" 
     data-src="/images/sample_07.jpg" 
     width="960" height="593" alt=""> 
<img loading="lazy" class="lazyload" 
     src="" 
     data-src="/images/sample_08.jpg" 
     width="960" height="593" alt=""> 
<img loading="lazy" class="lazyload" 
     src="" 
     data-src="/images/sample_09.jpg" 
     width="960" height="593" alt=""> 
<img loading="lazy" class="lazyload" 
     src="" 
     data-src="/images/sample_10.jpg" 
     width="960" height="593" alt=""> 
<!-- data-src、data-srcset、 class="lazyload" の指定なし -->
<img loading="lazy" 
 src="/images/large/sample_11.jpg" 
 srcset="/images/small/sample_11.jpg 640w, /images/medium/sample_11.jpg 960w, /images/large/sample_11.jpg 1200w" 
 sizes="100vw"
 alt=""> 
<!-- data-src、data-srcset、 class="lazyload" の指定なし -->  
<picture>
  <source 
  media="(min-width: 1200px)" 
  srcset="/images/large/sample_12.jpg">
  <img loading="lazy" 
    src="/images/sample_12.jpg"
    alt="">
</picture>  
//loading 属性がサポートされていれば
if ('loading' in HTMLImageElement.prototype) { 
  //loading 属性に lazy が指定されている img 要素
  const images = document.querySelectorAll('img[loading="lazy"]');
  //data-srcset が指定されている img 要素
  const img_srcset = document.querySelectorAll("img[data-srcset]");
  //data-srcset が指定されている source 要素
  const sources = document.querySelectorAll("source[data-srcset]");

  //loading="lazy" が設定されている要素があれば
  if(images.length > 0) {
    images.forEach(img => {
    //data-src 属性が設定されていれば img 要素の src 属性の値に data-src 属性の値を設定
      if(img.dataset.src) {
         img.src = img.dataset.src;
      }
    });
  }
  //data-srcset が指定されている img 要素があれば
  if(img_srcset.length > 0) {
    img_srcset.forEach(img_srcset => {
      //img 要素の srcset 属性の値に data-srcset 属性の値を設定
      img_srcset.srcset = img_srcset.dataset.srcset;
    });
  }
  //picture 要素
  //data-srcset が指定されている source 要素があれば
  if(sources.length > 0){
    sources.forEach(source => {
      //source 要素の srcset 属性の値に data-srcset 属性の値を設定
      source.srcset = source.dataset.srcset;
    });
  }
} else {
  //loading 属性がサポートされていない場合は動的に lazysizes ライブラリーを読み込む
  // script 要素を生成
  const script = document.createElement('script');
  //ダウンロードしてある lazysizes を script 要素の src に指定
  script.src = 'lazysizes.min.js';
  //script 要素を body に追加
  document.body.appendChild(script);
}