首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

图片按需加载js

图片按需加载(也称为懒加载)是一种优化网页性能的技术,它只在用户需要查看图片时才加载图片,而不是一次性加载页面上的所有图片。这种技术可以显著减少页面的初始加载时间,提高用户体验,特别是在移动设备和网络条件较差的情况下。

基础概念: 图片按需加载通常涉及到监听滚动事件,判断图片是否进入可视区域,如果进入则加载图片。这个过程可以通过JavaScript实现,也可以使用现成的库或框架来简化开发。

相关优势:

  1. 减少初始页面加载时间,提升用户体验。
  2. 节省带宽资源,特别是在移动网络环境下。
  3. 减少服务器压力,因为不是所有的图片都会在同一时间被请求。

类型:

  1. 基于滚动事件的懒加载:通过监听window的scroll事件,判断图片是否进入视口。
  2. 基于Intersection Observer API的懒加载:这是一种更现代的方法,通过Intersection Observer来监测元素是否进入视口,性能更优,代码更简洁。
  3. 预加载(Preloading):在用户可能需要之前就加载某些资源,这可以和懒加载结合使用,以进一步优化用户体验。

应用场景:

  • 图片密集的网站,如电商网站的产品列表、社交媒体平台、图片分享网站等。
  • 移动应用中的图片加载。

遇到的问题及原因:

  1. 图片闪烁:由于图片在进入视口时才开始加载,可能会导致布局的变化,从而引起闪烁。解决方法是设置图片容器的占位符,保持布局稳定。
  2. 滚动事件性能问题:频繁触发滚动事件可能会导致页面卡顿。使用节流(throttling)或防抖(debouncing)技术可以缓解这个问题,或者使用Intersection Observer API来避免直接监听滚动事件。
  3. 图片加载失败:网络问题或服务器问题可能导致图片加载失败。需要有相应的错误处理机制,比如重试策略或者显示备用图片。

如何解决这些问题:

  • 使用CSS设置图片容器的固定宽高,确保在图片加载完成前有占位,避免布局变动。
  • 使用Intersection Observer API代替滚动事件监听,以提高性能。
  • 对于加载失败的图片,可以使用onerror事件处理器来提供备用图片或者重试加载。

示例代码(使用Intersection Observer API):

代码语言:txt
复制
document.addEventListener("DOMContentLoaded", function() {
  var lazyImages = [].slice.call(document.querySelectorAll("img.lazy"));

  if ("IntersectionObserver" in window) {
    let lazyImageObserver = new IntersectionObserver(function(entries, observer) {
      entries.forEach(function(entry) {
        if (entry.isIntersecting) {
          let lazyImage = entry.target;
          lazyImage.src = lazyImage.dataset.src;
          lazyImage.classList.remove("lazy");
          lazyImageObserver.unobserve(lazyImage);
        }
      });
    });

    lazyImages.forEach(function(lazyImage) {
      lazyImageObserver.observe(lazyImage);
    });
  } else {
    // 回退到滚动事件监听的代码
  }
});

在这个示例中,图片元素需要有一个lazy类和一个data-src属性,后者存储了图片的真实URL。当图片进入视口时,Intersection Observer会将其src属性设置为data-src的值,从而触发图片加载。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

按需加载js和css

博客上有一个用mediaelement-and-player.js弄的播放器,插件默认的是每个页面都加载一次mediaelement-and-player.min.js和mediaelementplayer.min.css...,两个文件都十分的庞大,加起来接近100k,虽然gzip之后只剩下20多k但是也是十分地不爽,所以我便寻思着有没有什么办法能有播放器的时候就加载它,没有播放器的时候就不加载。...首先往后端的方向去想,由于不知道typecho的js是怎么管理的,似乎在插件的激活方法中就开始往模板输出js和css了,我要的是在分析文章的过程中决定要不要输出那个js,所以要从后端来着手去搞的话难度很大...于是我往前端去思考,我们都知道html网页都是由dom组成的,假如我们判断到可以加载播放器的时候再让它document.write()出那个代码同也就能实现这个功能,而且对后端没什么影响。...这样那些用不上的js就不会加载啦,网页加载速度也会快不少。 不知道css放在页面底部会不会有什么副作用,目前还没遇到什么问题,望大神指点迷津。 不过我觉得这种方式应该是最愚蠢的╮(╯▽╰)╭

2.8K20
  • JS实现图片懒加载

    懒加载的实现原理 由于网页中占用资源较多的一般是图片,所以我们一般实施懒加载都是对图片资源而言的,所以这里的实现原理主要是针对图片。...大家都知道,一张图片就是一个标签,而图片的来源主要是src属性。浏览器是否发起亲求就是根据是否有src属性决定的。...实现步骤及Demo 1.先介绍几个和懒加载相关的API document.documentElement.clientHeight//获取屏幕可视区域的高度 直观的图解: element.offsetTop...可能到这里还有一些人不知道怎么实现,我们还是用图来展示一下: 看了这张图,我们就得出了一个判断公式: 如果:offsetTop-scroolTop图片进入了可视区内,则被请求...device-width, initial-scale=1.0"> 图片懒加载

    11.4K20

    vue按需加载组件

    Vue按需加载组件 #1 环境 "vue": "^2.5.2", "element-ui": "^2.12.0", "view-design": "^4.0.0", #2 需求 在完整导入iView组件之后...,iView不能满足需求,需要导入element组件,但是完成导入可能会导致文件过大,这时,需要按需求引入ele组件 #3 开始 #3.1 安装 借助 babel-plugin-component,...} ] ] } #3.3 引入 新建element 文件夹 在 src 文件夹中新建我们的 other_ui/element 文件夹,并在里面新建一个 index.js...} } export default element 注意: 这里要使用 Select 组件,必须同时使用 Option 和 OptionGroup 这里的 install 方法表示在 main.js...中,如果使用 Vue.use() 方法的话,则该方法默认会调用 install 方法 在 main.js 中使用该文件,就大功告成了 // 按需加载element组件 import 'element-ui

    1.4K20

    htmlimg图片加载失败_js针对图片加载失败的处理方法分析

    本文实例讲述了js针对图片加载失败的处理方法。...分享给大家供大家参考,具体如下: 在项目中不可避免会用到图片,尤其是列表,有时候图片会加载失败;这样就会显示一个很难看的坏图片缩略图;下面介绍两种方法,解决这个问题: 1、如果在你的项目中有引入jQuery...插件,你可以使用error([[data],fn])这个函数; $(“img”).error(function(){ //当图片加载失败时,你要进行的操作 //$(this).attr(‘src’,...object.addEventListener(“error”, myScript); 支持的 HTML 标签: , , , 另外,当图片加载错误的时候,触发onerror事件,还可使用一下方法进行处理...用默认的图片替换 PS:这里再为大家附上javascript系统自带事件参考表供大家参考查询: 希望本文所述对大家JavaScript程序设计有所帮助。

    6.6K20

    JS判断单、多张图片加载完成

    试想,如果模板中有图片,此时如何判断图片是否加载完成? 在此之前来了解一下jquery的ready与window.onload的区别,ready只是dom结构加载完毕,便视为加载完成。...(此时图片没有加载完毕),onload是指dom的生成和资源完全加载(比如flash、图片)出来后才执行。接下来回到正题,先从单张图片说起。..."> //js $(document).ready(function(){ //jquery $('#xiu').load(function(){ // 加载完成...3、以下内容省略兼容 (2)、单张图片(图片动态生成) //js var xiu = new Image() xiu.src = 'http://www.daqianduan.com/wp-content.../uploads/2014/11/hs-xiu.jpg' xiu.onload = function(){ // 加载完成 } (3)、单张图片(结合ES6 Promise) //js

    12.5K20

    JS使用lazyload进行图片懒加载

    原理: 图片的加载是由src引起的,当对src赋值时浏览器会请求图片资源,基于这个,可以利用html5的属性data-xxx来保存图片的路径,当我们需要加载图片的时候才将data-xxx的值赋予src...就能实现图片的按需加载了,也就是懒加载了 方法: 1.使用lazyload插件,引用jquery.js和jquery.lazyload.js 2.将img标签中的src属性赋值为加载图片,即一张临时的...loading.gif图,将真正的图片路径放在data-original属性中 3.当JS监听到该图片元素进入可视窗口时,将data-original属性中的地址存赋予到src属性中,达到懒加载的效果...引用 //html //js $('ul img').lazyload() 这样就完成了最简易的图片懒加载了 可自行拓展延伸 window.addEventListener...('DOMContentLoaded', function() { //后端分页进行滚动加载 $(function () { var pageNo = 1, //页码

    3K10

    按需加载 AngularJS 的 Controller

    按需加载 AngularJS 的 Controller 多视图应用 AngularJS 通过路由支持多视图应用, 可以根据路由动态加载所需的视图, 在 AngularJS 的文档中有详细的介绍, 网上也有不少教程...随着视图的不断增加, js文件 会越来越多, 而 AngularJS 默认需要把全部的 js 都一次性加载, 使用起来非常不便, 因此按需加载模块的需求会越来越强, 不过, AngularJS 并没有实现按需加载...模块在加载的过程中什么都没做, 可以按照任意顺序加载, 因此脚本加载器可以使用这个特性进行并发加载。...}); }); return defered.promise; } } }); 为此, 可以单独写一个 loader.js...defered.promise; }] }; return definition; } }); 将应用的路由单独放在一个 route.js

    1.2K10

    Webpack插件按需加载组件_webpack懒加载

    为了解决上面问题,我们需要对Vue实现组件懒加载(按需加载)。 阅前悉知: 下面,我将简单讲解一下Javascript的懒加载(按需加载)原理以及在Vue上的应用。...借助函数实现懒加载(按需加载) 首先,我们先来回顾一下JavaScript函数的特性。.../con.js') } 目录结构如下: 打包后,运行项目: 可以看到,con.js实现了懒加载(按需加载)。...懒加载(按需加载)实现原理的概括 回顾前两节的内容,懒加载(按需加载)原理分为两步: 将需要进行懒加载的子模块打包成独立的文件(children chunk); 借助函数来实现延迟执行子模块的加载代码;...》 结语 至此,关于懒加载(按需加载) 的说明就结束了。

    1.5K20

    js - 预加载+监听图片资源加载制作进度条

    因为功能的特殊性,就要求我们提前监听页面的静态图片是否全部加载完毕。即处理预加载。...原来页面加载完毕后刷新,再展示的图片都是缓存的图,而load又监听不到缓存的图。 要了我的老命了。 于是我又找,什么方法能监听缓存的图啊? 目标锁定了js里的img.complete。...注意划重点是js的属性。...所以这里使用上要注意,因为我获取的dom对象是jq的,要转成js的再调complete属性,于是代码直接是: if(MyImg[0].complete){ // 用于缓存图片 sumAdd...为了友好的用户体验,你在后台加载图片的时候,用户不能只看到一个加载中,等半天不知道到底有没有反应。 所以我们要给用户一个及时的反馈,就要获取图片加载的进度。

    9.8K22

    实现图片懒加载jquery.scrollLoading.js

    首先需要jquery.min.js插件,我用的是jQuery v2.1.3,大家可以去百度搜很多自己引入全局顶部即可,当然你的程序自带就不需要在引用JQ了。...第一步 找到你的全局顶部文件,上面已经说了如果你程序自带jq就忽略即可,大概就这样吧 第二步 找到你的底部文件,增加两段jspiex.gif为你要首次懒加载的图片,图片大家可以自己去找或者用我的 点击查看懒加载图片...script> $(function () { $(".scrollLoading").scrollLoading(); }); 第三步 找到你的全局js...文件,粘贴下方的js。...实在不懂是哪个建议先进入到你的文章页按F12打开控制台看看加载了哪个js就扔进去 (function($) { $.fn.scrollLoading = function(options) {

    2.2K20

    AngularJS中的按需加载ocLazyLoad

    初学者,有不足的地方希望各位指出 一、前言     ocLoayLoad是AngularJS的模块按需加载器。一般在小型项目里,首次加载页面就下载好所有的资源没有什么大问题。...二、按需加载的对象 各个Controller模块、Directive模块、Server模块、template模板,其实这些都是一些 .js文件或者 .html文件 。    ...三 、按需加载的场景     三、1 路由加载(resolve/uiRouter) 基于uiRouter的resolve是在加载controller和template之前所执行的一系列操作,它帮助我们初始化我们所要前往的那一个视图.../AppCtrl.js') }] } })     其中,'js/AppCtrl.js'里面放着一个我们所需要的controller.../gridModule.js' ] }] }) 四、如何组织按需加载 分路由、按功能来区分、打包成不同的多个或单个controller.directive.server

    1.7K80

    lazyload.js实现图片异步延迟加载

    所谓图片异步加载,意思是不用一次把图片全部加载完,你可以叫它延迟加载,缓冲加载都行。...看看你有没有这JavaScript 所谓图片异步加载,意思是不用一次把图片全部加载完,你可以叫它延迟加载,缓冲加载都行。...看看你有没有这种需求:某篇文章图片很多,如果在载入文章时就载入所有图片,无疑会延缓载入速度,让用户等更久,所以,我想找这样一种插件,让网页只加载浏览器视野范围内的图片,没出现在范围内的图片就暂不加载,等用户滑动滚动条时再逐步加载...; 代码精简,便于操作维护,JS代码仅仅 1.6KB 先决条件是:你的站加载了 Jquery.js 原理: 这个特效是少有的即华丽又加速的效果,因为它能判断访客是不是在查看当前图片,若非则加载预留的填充图片...不用担心对访客的友好程度,这个效果会在图片即将被浏览到的时候就开始加载图片; 实现方法: 下载 jquery.lazyload.js      下载 预填充图片 fill.gif 点此打包下载

    12.8K20
    领券