前端性能优化-图片

简介: 前端性能优化-图片

JPEG

联合国图像专家小组是一种针对彩色照片而广泛使用的压损图形格式
介绍:栅格图形,常用文件扩展名为.jpg,也有.jpeg,.jpe,jpeg在互联网上常被应用于存储和传输照片

不适合:线条图形和文子,图标图形,因为他的压缩算法不在这些类型的图形,并且不支持透明

非常合适:颜色丰富的照片,彩色图大焦点图,通栏banner图,结构不规则的图形

PNG

便携式网络图形是一种无压缩的图形格式,支持索引,灰度,RGB,三种颜色

介绍:栅格图像,PNG最初作为代替GIF来设计的,能够显示256色,文件比JPEG大,但是PNG非常好的保留图像的质量。支持Alpha通道半透明和透明特性。最高支持24位彩色图像和8位灰度图像

不合适:由于无损存储,彩色图像体积太大,所以不合适

合适:纯色,透明。线条绘图,图标,边缘清晰,有大块相同颜色区域,颜色数较少但需要半透明

GIF

图像互换格式是一种位图形文件格式,以8位色(既256中颜色)重现真彩色的图图像,才有LZW雅俗算法进行编码

介绍:栅格图像,支持256色,仅支持完成透明和完全不透明;如果需要比较通用的动画,GIF是唯一的选择

不合适:每个像素只有8比特,不适合存储彩色图片

合适:动画,图标

webp

是一种现代图像格式,可为图像提供无压缩和有损压缩,这使得他非常灵活,有Google在购买On2 Technologies后发展出了,以BSD授权条款发布

介绍:优秀算法能同时保证一定程度上的图像质量和较小的体积,可以插入多帧,实现动画效果,可以设置透明度,采用8位压缩算法,无损的webp比png小26%,有损的webp比JPEG小25-34%,比GIF有更好的动画

不合适:最多处理256色,不适合彩色图片

合适:适用于图行和半透明图像

用工具进行图片压缩

压缩png

  • 使用node-pngquant-native
  • 跨品台,压缩比高,
  • 安装 cnpm install node-pngquant-native cnpm install jdf-png-bative
  • 使用方法

    var pngquant = reuqire('node-pngquant-native')
    var fs = require('fs')
    fa.readFile('图片地址',function(err,buffer) {
        if(err) throw err
        var resBuffer = pngquant.option({}).compress(buffer)
        fs.writeFile('输出图片名称',resBuffer,{
            flags:'wb'
        },function(err){})
    })

    压缩jpg

    • 使用jpegtran
    • 跨品台,有linux,mac,windows的解决方案
    • 安装 cnpm i jpegtran -g
    • 使用方法

      jpegtran -copy none -optimize -outfile 压缩之后图片 in 要压缩图片
  • 压缩gif

    • Gifsicle 通过改变每帧的比例,减少gif文件大小,同时可以有使用透明来达到更小文件大小,
    • 使用方式

      • 优化级别设置不小于2,1的话基本不压缩,gifsicle --optimize=3 -o out.gif in.gif
      • 将透明部分截取gifsicle --optimize=3 --crop-transparency -o out.gif in.gif

响应式图片

  • javascript绑定事件监测窗口大小
  • CSS媒体查询

    @media screen and (max-width:640px) {
        my_images{width:640px}
    }
    • img标签属性
    <img srcset="img-320w.jpg,img-640w.jpg 2x,img-960.jpg 3x" src="img-960w.jpg" ></img>
    x描述符表示图像的设备像素比

代替图片

  • 使用Data URI代替图片
  • web Font代替图片
  • 采用Image spritinh(雪碧图)

逐步加载图片

  • 使用LQIP
  • 低质量图像占位符
  • 安装 cnpm install lqip

    使用方法

    const lqip = require('lqip')
    
    const file = './1_govern66.jpg'
    lqip.base64(file).then(res => {
        console.log(res);
    })
    
    lqip.palette(file).then(res => {
        console.log(res);
    })

    通过运行node 会把图片的base64位打印出来,

image-20200426094615261.png

  • 使用SQIP
  • 基于SVG的图像占位符

    • 安装cnpm install sqip
    • 使用方法

      const sqip = require('sqip')
      
      const result = sqip({
          filename: './1_govern66.jpg',
          numberOfPrimitives: 10
      })
      console.log(result.final_svg);
    • 通过运行node打印的结果是把图片转换成SVG的格式

image-20200426095107387.png

以后就是常见的前端对图片的优化方案

目录
相关文章
|
26天前
|
前端开发 JavaScript UED
深入了解前端性能优化:提高用户体验的关键
【10月更文挑战第9天】深入了解前端性能优化:提高用户体验的关键
42 5
|
24天前
|
存储 前端开发 JavaScript
🚀前端轻松实现网页内容转换:一键复制、保存图片及生成 Markdown
在现代前端开发中,提升用户的交互体验至关重要。本文将详细介绍如何使用 HTML2Canvas 和 Turndown 两个强大的 JavaScript 库,实现将网页选中文本转化为图片并保存或复制到剪贴板,或将内容转换为 Markdown 格式。文章包含核心代码实现、技术细节和功能拓展方向,为开发者提供了一个轻量级的解决方案,提升用户体验。
115 68
|
7天前
|
缓存 前端开发 JavaScript
前端性能优化:Webpack与Babel的进阶配置与优化策略
【10月更文挑战第28天】在现代Web开发中,Webpack和Babel是不可或缺的工具,分别负责模块打包和ES6+代码转换。本文探讨了它们的进阶配置与优化策略,包括Webpack的代码压缩、缓存优化和代码分割,以及Babel的按需引入polyfill和目标浏览器设置。通过这些优化,可以显著提升应用的加载速度和运行效率,从而改善用户体验。
22 5
|
9天前
|
缓存 监控 前端开发
前端工程化:Webpack与Gulp的构建工具选择与配置优化
【10月更文挑战第26天】前端工程化是现代Web开发的重要趋势,通过将前端代码视为工程来管理,提高了开发效率和质量。本文详细对比了Webpack和Gulp两大主流构建工具的选择与配置优化,并提供了具体示例代码。Webpack擅长模块化打包和资源管理,而Gulp则在任务编写和自动化构建方面更具灵活性。两者各有优势,需根据项目需求进行选择和优化。
36 7
|
8天前
|
缓存 前端开发 JavaScript
前端工程化:Webpack与Gulp的构建工具选择与配置优化
【10月更文挑战第27天】在现代前端开发中,构建工具的选择对项目的效率和可维护性至关重要。本文比较了Webpack和Gulp两个流行的构建工具,介绍了它们的特点和适用场景,并提供了配置优化的最佳实践。Webpack适合大型模块化项目,Gulp则适用于快速自动化构建流程。通过合理的配置优化,可以显著提升构建效率和性能。
22 2
|
15天前
|
缓存 前端开发 JavaScript
前端性能优化:打造流畅用户体验的秘籍
【10月更文挑战第20天】前端性能优化:打造流畅用户体验的秘籍
27 3
|
14天前
|
存储 缓存 算法
前端算法:优化与实战技巧的深度探索
【10月更文挑战第21天】前端算法:优化与实战技巧的深度探索
13 1
|
14天前
|
缓存 前端开发 JavaScript
如何优化前端资源
如何优化前端资源
|
15天前
|
监控 前端开发 JavaScript
前端性能优化:打造流畅用户体验的秘籍
【10月更文挑战第20天】前端性能优化:打造流畅用户体验的秘籍
24 2
|
26天前
|
缓存 前端开发 JavaScript
前端性能优化策略
【10月更文挑战第9天】前端性能优化策略
22 6