Skip to content
On this page

图片优化

optimze image - 基于imagemin库的图片优化的脚本已在github上共享,有需要的可以使用。

压缩图片

方法一:
执行上述提供的脚本来将所需要的图片进行压缩,压缩时需要输入图片质量(1-100)。目前支持png/jpg/jpeg格式的图片压缩。压缩的实战结果理想,与tinyPNG的效果相当甚至更理想。 脚本执行完成后在对应的文件夹下可得到结果。

方法二:
通过 TinyPNG 平台将图片导入,压缩完成后下载。

Webp格式

随着webp图片格式的优势,目前浏览器的图片开始流行。图片资源更小清晰度更好让我们在开发时能够更好的优化项目。

在执行脚本的过程中可以选择进行图片压缩或者进行图片的webp格式转换,同时也需要输入转换的质量。脚本执行完成后在对应的文件夹下可得到结果。

在搜索引擎中查找到的webp转换网址的效果都很不理想,最理想的情况还是使用imagemin的库来进行webp的格式转换。

懒加载

延迟加载页面中的图片,只在图片进入可视区域时才进行加载。可以使用Vue插件(如vue-lazyload)或原生JavaScript实现。也可以自定义Vue的指令实现懒加载功能。

写了一个简易的图片懒加载代码示例:

ts
import { DirectiveBinding, Directive } from 'vue';

const placeholderSrc = '';

// 定义自定义指令
const ImgLazyLoad: Directive<HTMLImageElement, unknown> = {
  beforeMount(el: HTMLImageElement, binding: DirectiveBinding) {
    const imgUrl = el.src;
    el.src = placeholderSrc;
    
    const lazyImg = new Image();
    lazyImg.src = imgUrl;
    lazyImg.onload = (e) => {
      el.src = imgUrl;
    }
  }
};

export default ImgLazyLoad