周天记 我在人间混日子

Typecho实现全站图片懒加载

对于博客网站来说,图片加载慢是导致网站迟迟加载不完的罪魁祸首,本站实现了所有图片懒加载,这里分享下本站是如何实现的,整体过程也比较简单。本站教程基于Typecho,其它博客程序请自行研究,不过区别并不大。

我这里使用的 lazysizes.min.js 来实现懒加载。有必要简单介绍下LazySizes

LazySizes简介

LazySizes是一款终极而轻量级的懒加载库,专门用于处理响应式图片、iframe以及脚本等资源的延迟加载。其核心特性包括:

  • 高性能:旨在提供极高的性能表现。
  • 易于集成:只需在你的网页中加入JS文件,并对需懒加载的元素添加lazyload类即可。
  • 自适应图片:全面支持响应式图片标准,如标签和srcset属性。

主要功能亮点

  • 自动优先级资源管理,区别对待关键和临近视口的元素,提高感知性能。
  • 兼容性广泛,适用于各种前端框架和动态页面技术。
  • 支持未来的响应式图片规范,无需额外配置。
  • 提升SEO,不会影响搜索引擎抓取。

引入LazySizes

github下载地址

其它安装方式

npm install lazysizes --save
yarn add lazysizes --save

使用

使用上也比较简单,在需要使用的类上添加 lazyload 即可,比如我这里

<img class="comment-list-empty-img lazyload" 
     src="<?php $this->options->themeUrl('/static/images/null.svg'); ?>"
     data-src="<?php $this->options->themeUrl('/static/images/null.svg'); ?>"
     alt="<?php echo _t('暂无评论数据'); ?>"
>

评论区

😃
放弃
提交

全部评论 52

  1. 头像
    似水流年 Lv2 回复
    我一直以为你这个是wp,这个模板我见过类似的。
    · 河南 · GNU/Linux / Google Chrome
    1. 头像
      满心 博主 回复
      @似水流年 你说的应该是莫比乌斯的,他是WP的,我参照他的魔改了tp的
      · 湖北 · Windows 10 / Google Chrome
      1. 头像
        似水流年 Lv2 回复
        @满心 他的有些文章我读得有点吃力,跟不上。
        你俩都是勤更新的博主。
        · 河南 · GNU/Linux / Google Chrome
        1. 头像
          满心 博主 回复
          @似水流年 我比较随和,平时有时间有想法,就会多写写,没啥时间,也会隔很久的
          · 湖北 · Windows 10 / Google Chrome
  2. 头像
    文案姐笔记 Lv2 回复
    这个可以呀还可以节省服务器宽带!
    · 江苏 · Windows 10 / Google Chrome
    1. 头像
      满心 博主 回复
      @文案姐笔记 是呀,网站速度很关键呀
      · 湖北 · Android 15 / 手机微信
  3. 头像
    刘郎 Lv4 回复
    我直接原图上传 😳 但上传后服务器会自动压缩一点 咦 我发现个问题 现在这个页面对移动端不太友好了 视面左右晃动挺严重的
    · 贵州 · GNU/Linux / Google Chrome
    1. 头像
      满心 博主 回复
      @刘郎 我刚试了下,好像是的,我看看啥情况
      · 湖北 · Android 15 / WebView
    2. 头像
      满心 博主 回复
      @刘郎 有空的话,再帮忙看下,页面还晃动不,我自己测好像正常了
      · 湖北 · Windows 10 / Google Chrome
      1. 头像
        刘郎 Lv4 回复
        @满心 不晃了
        · 贵州 · GNU/Linux / Google Chrome
        1. 头像
          满心 博主 回复
          @刘郎 好滴,感谢感谢
          · 湖北 · Windows 10 / Google Chrome