前端性能优化

文章探讨了如何优化网页性能,包括懒加载和预加载技术,如图片的延迟加载和列表的分片渲染。同时,介绍了HTTP缓存机制,如强缓存和协商缓存,以及代码结构优化,如CSS放在头部,JS放在底部,和JavaScript的压缩与优化策略,如防抖和节流。此外,提到了图片压缩方法,如base64编码和WebP格式。
摘要由CSDN通过智能技术生成

资源加载(减少http请求数)

懒加载

  1. 图片

    视图外的图片不加载,图片进入可视范围后再加载

    • 原理:图片初始化时,显示默认静态图片(src属性),图片进入可视范围后,将src替换为图片真实url地址
    • 实现:
      • 元素距页面顶端的位置 < 浏览器窗口大小 + 网页上方的滚动高度
        el.offsetTop < el.clientHeight + document.documentElement.scrollTop
      • 元素的顶部在视口范围内
        getBoundingClientRect()
      • 元素和视口范围有交叉
        intersectionObserve()
  2. 组件

    js模块:动态import

预加载

预先加载后续内容

列表渲染

  1. 分片渲染
    • 时间分片
    • 分页渲染
  2. 虚拟列表
    • 只加载可视范围的列表,计算当前数据首尾索引,只渲染这些数据,其余的数据删除

图片压缩

  1. base64

    将较小的图片以base64格式内嵌到html中

    webpack url-loader配置

  2. WebP

    google推出的图片格式,能压缩图片大小

  3. SVG

  4. 缩略图

    列表展示图片时使用缩略图

  5. 精灵图

    多张图片合并为一张大图,使用background-pisition设置图片位置

HTTP缓存

  1. 强缓存

    缓存过期前,强制使用缓存数据,不发送新请求

    响应头中设置:

    • Cache-Control: max-age = <second>

      资源过期秒数

    • Expries: <Time>

      资源过期时间戳

  2. 协商缓存

    缓存过期后,和服务器协商确认数据是否要更新

    响应头中设置:

    • Last-Modify: <Time>

      资源最后被修改的时间戳

    • If-Modified-Since: <Time>

      资源过期后,向服务器发送请求,询问“该时间戳后该资源是否有被更改”

      服务端比对If-Modified-Since与服务器中该资源的最后修改时间

      无修改:返回304

      修改:返回200 + 最新数据

    • ETag

      可以为hash值或版本号

    • If-None-Match

代码结构

  1. CSS写在<header>尾部,JS写在<body>尾部

    html解析前就能加载CSS形成CSSOM,更早地合并DOM渲染

    JS会阻塞页面渲染,且可能改变页面结构,

脚本优化(JS)

  1. 压缩文本资源

    去掉多余空格,移除注释或无用变量

  2. 防抖节流

  3. 事件委托

  4. 哈希表缓存

  5. 防止内存泄漏

  6. 减少重绘回流

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值