当前位置: 首页 > news >正文

vue的首屏优化是怎么做的

可以打开f12 的performanace 性能选项卡,然后点击开始录制,刷新页面,首次绘制FP,到首次绘制内容FCP之间的这个白屏没有了之后,点击结束 ,那么在这里就能看见哪个模块或者是网络原因用的时间长。
如果是网络原因

具体优化细节

1、基础的优化
  • 优化图片: 推荐webP 格式,不用要太大的图片(头像上传控制 size 200 * 200)
  • 组件按需加载:React Suspense + Reace.lazy
  • 延迟加载: 滚动加载,可视区域渲染。
  • tree-shaking: 通过代码编写的方法约定,tree-shaking需要什么条件?esm(模块化,如果使用cmd commonjs,是不可以的)
  • CDN: oss+cdn
  • 精简第三方库: antd\mantine\mui\nextui\arco UI , 库的内容按需导入, 国际化文件,要移除
  • 缓存(强缓存 (Expire, Cache-control),协商缓存(Last-Modified、If-Modified-Since\Etag\ if-None-match),策略缓存 service-worker)
  • 字体压缩: font-spider 移除无用字体,webfont 预加载
  • SSR(server side render)\ SSG (Server side generate)
  • 骨架屏 或者增加loading动画
2、进阶优化
  • 预加载:
    preload; 在vue-router 的import()中设置/ * webpackPrefetch: true * /
    ``<link rel=‘preload’ href=‘XXX.js’, as=‘script’>
    在vue3+vite 项目中,预加载的核心实现方法包括: 配置optimizeDeps.include 预构建依赖、使用vite-plugin-optimize-rersist自动优化预加载配置,以及通过动态导入和路由懒加载实现按需预加载。
    vue-router会默认支持动态导入,使用 import()这种形式,如果想跳过低频的路由的话使用 /* @vite-ignore*/
  • 加载关键css, 将关键的css直接嵌入到html 中,以避免阻塞渲染,通过内联关键样式,可以确定在解析和渲染html 时,关键样式已经可用,这样页面加载速度更快,用户会更早地看见内容。
  • 使用延迟装载 defer : 写一个userDefer 方法, 创建一个响应式变量,每加一帧,增加1
import {ref} from 'Vue'
const count = ref(0)
function update(){count.value ++;requestAnimationFrame(updata)
}
updata()
export function useDefer(){return function(n){return count.value > = n
}
}
  • 非关键js 异步加载 使用defer 或者 async
    1、 defer:可以改变浏览器处理javscript脚本的方式,带有defer的脚本不会阻塞HTML的解析,而是并行下载defer的脚本,等到html解析完成后,再顺序执行。
    2、async :也可以改变浏览器处理javascript脚本的方式,带有async的脚本不会阻塞html的解析,而是异步加载脚本,加载完毕后尽快执行,不用等到其他脚本和html解析完成,可能会导致html的解析中断。

  • 异步组件async

  • 预渲染

http://www.dtcms.com/a/412541.html

相关文章:

  • 地方网站建站平台全国失信被执行人名单查询
  • Linux --- 软件包管理器
  • 网站系统升级邯郸网站关键字优化
  • 网站能获取访问者中国做木线条的网站
  • 莱芜市莱城区城乡建设局网站一站式婚庆公司
  • 沈阳专门代做网站的上海做网站收费
  • 牛批了,Windows批量工具
  • 潮州专业网站建设报价在工商局网站做变更需要多久
  • 兰州网站做的好点的公司怎么做贷款网站
  • 做网站用什么工具好沈阳网站建设开发维护
  • excel函数公式大全!含基础操作与函数练习资源
  • 做网站需要视频衔接怎么修改文案支持在线图片编辑
  • 做网站第一步潜江资讯网房屋出租
  • (29) 运动目标检测之python多线程调用YOLO检测
  • 南京手机网站设计公司表白网站制作模板
  • 碳纤维:改变世界的 “黑色黄金”
  • 桂林网站制作网站wordpress主题noren
  • 如何做制作头像的网站电商平台搭建方案
  • 哪有做奇石网站微信专业开发
  • 站长工具seo诊断网站建设与管理好过吗
  • 从哪些方面做好网站的seophp做电子商城网站
  • 深入浅出地讲解如何使用CURL命令行工具进行API测试
  • 网站版面的图文是怎么做的门户网站ip地址段
  • 笔记:现代操作系统:原理与实现(4)
  • 基于OFDM+QPSK调制解调的通信链路matlab性能仿真,包含同步模块,信道估计和编译码
  • 宁波网站推广方式西樵网站制作公司
  • apache建设网站网站设计公司官网
  • 桂林北站是高铁站吗以公司做网站
  • 【anaconda】anaconda安装配置,git安装配置以及pytorch安装
  • 仓颉编程语言青少年基础教程系列汇总