原生手动实现懒加载
            
              
                
                  本文最后更新于:2023年3月19日 晚上
                
              
            
            
              重点是如何判断是否在视窗内
1 2 3 4 5
   | const viewPortHeight = window.innerHeight; const offsetTop = el.offsetTop; const scrollTop = document.documentElement.scrollTop; const top = offsetTop - scrollTop; return top <= viewPortHeight + 100;
 
  | 
 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195
   | <!DOCTYPE html> <html lang="en">   <head>     <meta charset="UTF-8" />     <meta name="viewport" content="width=device-width, initial-scale=1.0" />     <title>Document</title>   </head>   <body>     <div       style="width: 100vw;height: 3000px;display: flex;flex-direction: column;"     >       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />       <img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       /><img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       /><img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       /><img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       /><img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       /><img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       /><img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       /><img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       /><img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       /><img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       /><img         src="https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"         data-url="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1600664088205&di=d9ba384447ddd9e91146950c1fe4f7f4&imgtype=0&src=http%3A%2F%2F5b0988e595225.cdn.sohucs.com%2Fimages%2F20170823%2Fa248070c2ec342a7af7c94a4ed1ee3d6.png"         alt=""       />     </div>     <script>       const isInViewport = (el) => {         const viewPortHeight = window.innerHeight;         const offsetTop = el.offsetTop;         const scrollTop = document.documentElement.scrollTop;         const top = offsetTop - scrollTop;                  return top <= viewPortHeight + 100;       };
        const throttle = (fn, delay) => {         let timer = null;         return (...args) => {           let context = this;           if (!timer) {             fn.apply(context, args);             timer = setTimeout(() => {               timer = null;             }, delay);           }         };       };
        const handleScroll = () => {         if (document.documentElement.scrollTop === 0) return;         const imagesDom = document.getElementsByTagName("img");                  for (const dom of imagesDom) {           if (isInViewport(dom)) {             dom.setAttribute("src", dom.getAttribute("data-url"));           } else {             dom.setAttribute(               "src",               "https://upload-images.jianshu.io/upload_images/10862849-ca1fcf2d02453a08.jpg?imageMogr2/auto-orient/strip|imageView2/2/w/240/format/webp"             );           }         }       };
        window.onscroll = throttle(handleScroll, 500);     </script>   </body> </html>
 
  |