首页 > 其他分享 >前端性能优化:如何有效提升网页加载速度 面试必备

前端性能优化:如何有效提升网页加载速度 面试必备

时间:2024-09-13 23:26:08浏览次数:20  
标签:const 请求 必备 用户 视图 网页 优化 加载

为什么要进行性能优化呢

进行性能优化的原因是因为:性能的体现对干产品的影响是非常大,那么为了保证用户的留存率和转化率,我们就需要提升应用的响应速度 交互体验。以保证竞争力。

性能优化如何衡量

性能优化如何衡量, 也就是性能优化的标准是什么?
游览器中控制台呢有两个重要选项NetworkPerformance

Network主要功能和指标:
  • 请求和响应时间:显示每个网络请求的发起时间、完成时间、以及请求和响应所花费的时间(即网络延迟)。
  • 文件大小:展示每个请求的文件大小,有助于分析资源的大小是否影响了加载时间。
  • 请求类型:标明请求的类型(如文档、脚本、样式表、图像等),可以帮助识别加载哪些资源可能造成性能瓶颈。
  • HTTP 状态码:显示服务器对请求的响应状态码(如200、404、500等),有助于诊断请求失败的问题。
  • 缓存:显示资源是否从缓存中加载(如CacheMemory Cache),帮助了解缓存策略的效果。
  • Timeline:提供请求的时间线视图,帮助识别资源加载的顺序和时间分布。
  • Headers:查看请求和响应的HTTP头信息,以了解请求的具体细节和服务器的响应
    Network面板主要关注网络请求和资源加载情况,帮助优化资源大小和请求效率。

Performance面板提供了详细的运行时性能数据,帮助深入分析和优化页面的加载和执行性能。

要衡量的重要指标

太麻烦?看不懂可以安装lighthouse插件

请添加图片描述

请添加图片描述

项目性能优化方案

数据懒加载

查看当前页面,我们可以发现:用户是没有办法一下子看完所有数据的,他需要滚动页面,才可以看到后续的数据。
那么在很多情况下就会存在这样的情况:用户可能看到第一行的商品就直接点击进入详情页面了,也就是用户可能永远都不会看到最后一行数据。那么基于这个条件,我们最后一行数据,是不是就是不需要展示的数据。那么既然是不需要展示的数据,我们是不是就应该在一开始不获取数据,等到用户将要看到它的时候,在进行数据获取和展示呢?

那么,我们就把这样一个一开始不获取数据,等到用户将要看到它的时候,再进行数据获取和展示的功能,叫做数据懒加载。

那么这样的一个数据懒加载的功能如何进行实现呢?
根据我们刚才所说,整个数据懒加载的功能一共被分为三个阶段:

  1. 不获取数据
  2. 用户将要看到
  3. 获取数据并染
    在这三个阶段中,第一和第三都比较简单,最重要的就是第二如何判断用户将要看到

    那么想要实现这个目的,我们就需要利用利用到一个新的API,那就是IntersectionObsenver
    IntersectionObserve可以监听某一个视图是否被用户可见

    利用这intersectionObserverAPI,我们可以完成阶段二
    IntersectionObserver是web的原生API,在vue3中使用没有问题,但是会略显复杂。
    所以为此,vue的工具库vueuse提供了一个基于IntersectionObserver的封装方法
    uselntersectionObsenver 该方法基于IntersectionObserver完成,但是在应用层的使用中会更加方便

    相关代码实现
const box3Target = ref(null)
onMounted(() => {

// const intersectionObserver = new IntersectionObserver((entries) => {

// if (entries[0].intersectionRatio <= 0) {

// return console.log('当前视图不可见')

// }

// console.log('当前视图可见')

// })

// intersectionObserver.observe(box3Target.value)

  

const { stop } = useIntersectionObserver(

box3Target,

([{ isIntersecting }]) => {

if (isIntersecting) {

console.log('视图可见')

// 获取数据

loadData03()

// 触发 stop 监听停止

stop()

} else {

console.log('视图不可见')

}

}

)

})

图片懒加载

数据懒加载类似,咱们这里有很多的图片展示,但是用户不可能每次都看到最后的位置。那么换
而言,有很多的图片是没有必要加载的,我们只要看到图片的时候,在进行加载就可
但是:大家不要高兴的太早哦~。
我们知道IntersectionObserver在每次使用的时候, 必须传入dom对象。在数据懒加载中因为我们只需要监听一个或几个指定的容器,所以可以直接使用Intersection0bserver。
但是,在图片懒加载中,img标签是非常多的,我们不可能把每个img标签的dom对象都获取到对不对。
那么怎么办呢?
此时,咱们就需要使用到自定义指令的概念了
在vue3中,我们可以通过app.directive完成自定义指令。有了指令之后,我们只要在需要图
片懒加载的img标签处,写入该指令即可

import { useIntersectionObserver } from '@vueuse/core'

  

const imgLazy = {

mounted(el) {

// console.log(el)

// 图片懒加载:一开始不加载,等到将要看到时在加载

// 1. 缓存当前的图片路径

const catchSrc = el.src

console.log(catchSrc)

// 2. 把 img.src 变为占位图

el.src = 'https://res.lgdsunday.club/img-load.png'

// 3. 监听将要看到

const { stop } = useIntersectionObserver(el, ([{ isIntersecting }]) => {

if (isIntersecting) {

// 4. 渲染图片

el.src = catchSrc

// 5. 停止监听

stop()

}

})

}

}

  

export default {

// app.use 的方式使用

install: (app) => {

app.directive('imgLazy', imgLazy)

}

}

打包体积过大(CDN优化处理)

打包体积过大是因为第三方依赖包体积过大,而想要排除依赖包,那么需要使用webpackvite提供的外部扩展Extenals属性
防止将某些import的包(package打包到bundle中,而是在运行时(runtime)再去从外部获取这些扩展依赖(external dependencies)

现在,如果我们运行打包之后的项目,那么会得到一个错误可以利用 anywhere 运行打包之后的项目:
1.安装anywhere: npm -g anywhere
2.在dist目录下,执行终端命令: anywhere
3.自动启动服务
这是因为我们在上一小节排除依赖,导致依赖的第三方包找不到。
那么想要解决这个问题, 我们就需要使用到另外一个功能,那就是CDN引入。

const { defineConfig } = require('@vue/cli-service')

  

let externals = {}

let cdn = {

js: []

}

  

// 排除打包,只需要在 build 排除

const isProd = process.env.NODE_ENV === 'production'

if (isProd) {

externals = {

xlsx: 'XLSX',

echarts: 'echarts'

}

cdn = {

js: [

'https://cdn.jsdelivr.net/npm/echarts@5.4.2/dist/echarts.min.js',

'https://cdn.jsdelivr.net/npm/xlsx@0.18.5/dist/xlsx.full.min.js'

]

}

}

module.exports = defineConfig({

transpileDependencies: true,

configureWebpack: {

externals

},

chainWebpack(config) {

config.plugin('html').tap((args) => {

// 携带指定的属性到 htmlWebpackPlugin

args[0].cdn = cdn

return args

})

}

})

在index.html引入

<!DOCTYPE html>
<html lang="">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<link rel="icon" href="<%= BASE_URL %>favicon.ico">
<!-- 请求不添加请求来源 -->
<meta name="referrer" content="no-referrer" />
<title>
<%= htmlWebpackPlugin.options.title %>

</title>

<style>

* {

margin: 0;

padding: 0;

}

</style>

</head>

  

<body>

<noscript>

<strong>We're sorry but <%= htmlWebpackPlugin.options.title %> doesn't work properly without JavaScript enabled.

Please enable it to continue.</strong>

</noscript>

<div id="app"></div>

<!-- built files will be auto injected -->

<!-- 引入 js -->

<% for(var js of htmlWebpackPlugin.options.cdn.js) { %>

<script src="<%=js%>"></script>

<% } %>

</body>

</html>

CDN也有自己的缺点 虽然目前项目打包体积变小了,但是用户访问项目的体积没有变小
CDN只能增加用户访问的速度,但是并不会减少依赖包的体积。

其他优化方案
gzip压缩

首先咱们先说一下gzip压缩。我们在前面的打包中看到过gzip
Gzip通过LZ77算法与Huffman编码来压缩文件,重复度越高的文件可压缩的空间就越大,对JS、CSS、HTML等文本资源均有效。
Nginx返回js文件的时候,会判断是否开启gzip,然后压缩后再返回给浏览器
该压缩方法需要Nginx配置开启Gzip压缩,单纯前端通过webpack插件开启Gzip压缩是不能达到优化效果的。

http缓存

当我们日常刷新网页的时候,经常会遇到304状态码


304状态码表示:所请求的资源未修改,服务器返回此状态码时,不会返回任何资源。客户端通常会缓存访问过的资源,通过提供一个头信息指出客户端希望只返回在指定日期之后修改的资源。

不过在大多数况下 304的处理一般在服务框架中就进行处理 前端一般不需要过于关注

service worker

erviceworker是一个JSAPI 它的作用是:为网站提供有效的离线体验。在这里不做过多展开 可以去mdn查看。

最后

本文是Sunday老师视频的笔记 点击跳转

会持续更新前端文章 如果对你有用的话就点个关注吧

标签:const,请求,必备,用户,视图,网页,优化,加载
From: https://blog.csdn.net/weixin_63625059/article/details/142236027

相关文章

  • 第一章 网页制作的基础知识
    1.1认识网页和网站1.1.1网页、网站网页是构成网站的基本单位,是由HTML、CSS和JavaScript等技术创建的文档。它可以包含文本、图像、链接、表格和其他多媒体元素,用于向用户展示信息和提供交互功能。网站是由多个网页组成的集合,它们共同形成了一个完整的网络实体。网站旨在向......
  • HTML·第二章 网页制作的排版方法
    目录2.1文字与段落排版2.1.1段落标签2.1.2标题标签2.1.3换行标签2.1.4水平线标签2.1.5预格式化标签2.1.6缩排标签2.1.7案例2.2超链接2.2.1超链接简介2.2.2超链接的应用2.3图像2.3.1网页图像的格式及使用要点2.3.2图像标签2.3.3图像超链接2.3.4......
  • 什么是类加载器?类加载器有哪些
    什么是类加载器Java文件的编译和执行要想理解什么是类加载器首先要了解一个java文件是如何运行起来的类加载器:用于装载字节码文件(.class文件)运行时数据区:用于分配存储空间执行引擎:执行字节码文件或本地方法垃圾回收器:用于对JVM中的垃圾内容进行回收类......
  • ZooKeeper面试必备:ZooKeeper4种数据节点类型、了解事务ID
    1.ZooKeeper数据模型1.1ZooKeeper数据节点ZooKeeper的数据模型是一颗树结构,每一个树节点是一个数据节点,我们称它为ZNode。而每一个ZNode的节点路径标识使用斜杠/作为分隔符,我们可以在ZNode节点下写入数据、创建节点,这种斜杠/作为路径分隔符的方式和Unix文件系统路径非常相......
  • JS加载
    同步加载阻塞模式,提高安全性过多JS加载会影响页面效率默认情况下,JS是同步加载,及优先加载外部JS,只有当JS文件加载完成,don和css才开始加载<scriptsrc='index.js'></script>异步加载非阻塞加载动态创建scriptdefer延迟加载JS,等到HTML的DOM完全解析之后asyncHTML......
  • 『功能项目』项目优化 - 框架加载资源【41】
    我们打开上一篇40播放动画时禁止点击移动的项目,本章要做的事情是搭建一个资源加载框架,让UI界面,人物模型以及场景都存放在资源文件夹中在运行时加载出来首先在资源商店加载资源将怪物模型放置场景中将普通管线模型切换成URP重命名为Boss01放在资源文件夹里新建Boss01......
  • 第一章 网页制作的基础知识~
    1.1认识网页和网站网页和网站的区别:网站包含网页但是网页与网站有着很大的区别网站内还有包含网页以外的其他东西.(例如:服务器数据库等)但网站和网页不为总分关系,网页只是单独的一页.常用术语:Internet因特网www万维网web首页HTMY俗称电脑Hypertext超文本(......
  • Python网页应用开发神器Dash 2.18.1稳定版本来啦
    本文示例代码已上传至我的Github仓库:https://github.com/CNFeffery/dash-masterGitee同步仓库地址:https://gitee.com/cnfeffery/dash-master大家好我是费老师,上周Dash发布了2.18.0新版本,并于今天发布了可稳定使用的2.18.1版本(自古.1版本最稳✌),今天的文章中就将针对2.18.1......
  • 【编程小白必看】使用Selenium进行网页自动化操作操作秘籍一文全掌握
    【编程小白必看】使用Selenium进行网页自动化操作操作秘籍......