性能优化之前端项目性能优化的几种方案

news2025/1/11 1:19:36

加载优化,减少http请求

一个完整的 HTTP 请求需要经历 DNS 查找,TCP 握手,浏览器发出 HTTP 请求,服务器接收请求,服务器处理请求并发回响应,浏览器接收响应等过程。

  • Queueing: 在请求队列中的时间。

  • Stalled: 从TCP 连接建立完成,到真正可以传输数据之间的时间差,此时间包括代理协商时间。

  • Proxy negotiation: 与代理服务器连接进行协商所花费的时间。

  • DNS Lookup: 执行DNS查找所花费的时间,页面上的每个不同的域都需要进行DNS查找。

  • Initial Connection / Connecting: 建立连接所花费的时间,包括TCP握手/重试和协商SSL。

  • SSL: 完成SSL握手所花费的时间。

  • Request sent: 发出网络请求所花费的时间,通常为一毫秒的时间。

  • Waiting(TFFB): TFFB 是发出页面请求到接收到应答数据第一个字节的时间。

  • Content Download: 接收响应数据所花费的时间。

从这里可以看出,真正下载数据的时间占比为 1.50 / 65.45 = 2.29%。文件越小,比例越小,文件越大,比例就越高。这就是为什么要建议将多个小文件合并为一个大文件,从而减少 HTTP 请求次数的原因。

1.合并图片。合并成一个大图,如雪碧图(CSS Sprite)。

2.合并压缩html、css样式表和js脚本。如:webpack使用插件html-webpack-plugin打包合并html;使用插件extract-text-webpack-plugin打包独立的css;使用UglifyJsPlugin压缩代码。

3.去掉不必要的请求,如src、href等于空,浏览器会发起HTTP 请求。

4.首屏加载:快速显示首屏可以大大提高用户体验的感知页面速度,并应相应地进行优化。

5.充分利用缓存

Http缓存

强缓存

Cache-control
频繁变动的资源
Cache-Control: no-cache
不常变化的资源
Cache-Control: max-age=31536000
res.setHeader('Last-Modified', lastModified)      
res.setHeader('Cache-Control', 'no-cache,public,max-age=5')   
Expires (过时)
res.setHeader('Expires', new Date())

协商缓存

etag
let etag = md5(content); //可以以文件的内容是否修改对文件进行标记
let ifNoneMatch = req.headers['if-none-match'];
res.setHeader('ETag', etag); //if-none-match

浏览器缓存

Cookie 不可跨域请求;最多只能存4k。

console.log(document.cookie)
document.cookie = 'myname = ;path = /;domain = ';

LocalStorage 本地存储;不会清空。最多能存5m(所有key的总大小加起来)

window.localStorage;
localStorage.setItem(key, val);
localStorage.getItem(key);
localStorage.removeItem(key);

SessionStorage 会话存储;浏览器关闭即清空。

window.sessionStorage;
sessionStorage.setItem('person',JSON.stringify(person));
sessionStorage.getItem('person');

CacheStorage 只能缓存静态资源,Get请求;不会过期,需要定期清理;

caches.open(cacheName)

indexDB 存储大小250m以上;3d框架three.js中使用。

let indexedDB = window.indexedDB
const request = indexedDB.open(dbName, version)

websql

var db = openDatabase('mywebdbs', '1.0', 'Test DB', 1 * 1024 * 1024);
    
// 2.transaction对数据库db进行操作,里面传入函数,函数参数为被操作对象:(数据库的增)
db.transaction(function(dbtest) {
    // 1.通过executeSql执行SQL语句,create table if not exists CHART,来判断是否存在表CHART,不存在则创建名为CHART的表
    dbtest.executeSql('CREATE TABLE IF NOT EXISTS CHART (id unique, log)');
    // 2.通过executeSql执行SQL语句,向CHART表中插入一条数据结构为(id,log)值为(1,"hello word")的数据:
    dbtest.executeSql('INSERT INTO CHART (id,log) VALUES (1,"hello word")');
    dbtest.executeSql('INSERT INTO CHART (id,log) VALUES (2,"my name is jack")');
    // 扩展:dbtest.executeSql('INSERT INTO CHART (id,log) VALUES (?, ?)', [e_id, e_log]);里面的SQL语句为动态的插入数据
});
  1. 预加载:loading。

v-loading="loading"
element-loading-text="拼命加载中"
element-loading-spinner="el-icon-loading"
element-loading-background="rgba(0, 0, 0, 0.8)"

7.第三方资源异步加载。

{
    path: '/comment/:iid',
    name: '评论',
    component: resolve => require(['@/views/Editor'], resolve) // 异步加载非首屏页面
  },

8.使用http2。

图片优化

1.尽量用PNG格式的图片,比较小,可以用工具压缩。更好在上线前对它们进行优化。

2.延迟加载也被称为懒加载。

3.避免img、iframe等标签的空src属性:空src会重新加载当前页面,影响速度和效率。

4.尽量避免在图像中使用DataURL;不使用图像压缩算法,文件会变大,解码后需要很长时间才能加载。

使用CDN静态加速

https://www.aliyun.com/product/cdn

打开Gzip(代码压缩)

  1. html、js、css、图片等静态资源进行压缩;

  1. Nginx配置打开Gzip;

http {
      # 开启 gzip 压缩
      gzip  on;
      # 使用 gzip 压缩的文件类型
      gzip_types text/plain text/css application/javascript application/json text/xml application/xml application/xml+rss; 
      # 小于 256 字节的不压缩:压缩是需要时间的,太小的话压缩收益不大
      gzip_min_length 256;
      # 开启静态压缩:压缩的资源会被缓存下来,下次请求时就直接使用缓存
      gzip_static  on;
}
  1. 客户端浏览器查看Response Headers和Request Headers

样式表和js脚本文件的优化

1.标题中内嵌的样式和脚本会阻碍页面的呈现。一般把css样式表文件放在文件头,用link导入,这样可以尽快下载CSS样式表。

2.对于js脚本文件,我们通常把脚本放在最后,异步加载,尽量减少样式和脚本对页面的阻塞。

减少不必要的Cookies

代码性能优化

1.尽量使用事件委托:不是为每个子节点设置一个事件监听器,而是设置在其父节点上,然后利用冒泡原理设置每个子节点,避免批量绑定事件,减少内存消耗和DOM操作。

2.尽量使用id选择器:id选择器是选择元素最快的,具有唯一性、灵活性和优先级的优点。

3.设置Viewport:Viewport:HTML可以加快页面的渲染速度。

4.减少DOM节点:过多的DOM节点会影响页面的渲染。

5.尽可能使用css3动画:合理使用requestAnimationFrame动画,而不是setTimeout。

6.优化高频事件:滚动、触摸移动等事件受到防抖、节流等功能的限制。

7.避免滥用网页字体:网页字体需要下载,解析,重绘,尽量减少使用。

SEO优化

1. 标题: 标题字数不要太长,一般写核心的关键词和网站主题相关的内容。

2. 描述:描述是整个页面的综合说明,作用和重要性仅次于标题,描述最好能得吸引人一点,带上自己公司的品牌词和电话,并包括目标关键词。

3. 关键词:对关键词进行优化,能够让用户在搜索关键词的时候,能够准确的定位到自己要搜索的内容和网站,能够让网站被更多有需要的人看到。

4.网站代码:网站代码尽量精简,节约百度蜘蛛的时间,这一点针对大型网站特别重要。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/401120.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

5.1 STM32学习 中断系统和EXTI外部中断

中断系统中断:在主程序运行过程中,出现了特定的中断触发条件(中断源),使得CPU暂停当前正在运行的程序,转而去处理中断程序,处理完成后又返回原来被暂停的位置继续运行。中断优先级:当…

框架篇-面试题6-说一下Vue2与Vue3的钩子函数

Vue钩子函数是在Vue实例从创建到销毁的过程中自动执行的函数(在特定的阶段,能够自动自执行的函数)钩子函数用来描述一个组件从引入(创建)到退出(销毁)的全过程中的某个过程Vue2生命周期钩子函数整个过程称为生命周期Vue钩子函数按照组件生命周期的过程分…

作为一名程序员少不了的软件

写在前面的话 就现今我自己接触的项目而言,我发现对于一名程序员来说有些软件是真的必不可少的,防止下次换电脑或者要换操作系统的时候用,特此记录一下。 一、最常使用的,JetBrain全家桶(idea、pycharm、webstorm&…

【办公类-16-06-02】“2022下学期 总园活动室(沙水+建构)排班表(两周一次沙水)”(python 排班表系列)

作品展示:背景需求:上一篇批量制作了“7天轮回14班沙水每周固定建构”的活动室内排班表。一、时段冲突,调整单双周。保教主任抽空检查后,提到:“一个班、上午、下午都有自主游戏(沙水、建构、表演、角色&am…

金三银四、金九银十 面试宝典 JAVASE八股文面试题 超级无敌全的面试题汇总(接近3万字的面试题,让你的JAVA语法基础无可挑剔)

JavaSE八股文 - 面试宝典 一个合格的 计算机打工人 ,收藏夹里必须有一份 JAVA八股文面试题 ,特别是即将找工作的计算机人,希望本篇博客对你有帮助! 本文参考了诸多大佬的面试题帖子,ps:白大锅、哪吒、英雄…

从Linux内核中学习高级C语言宏技巧

Linux内核可谓是集C语言大成者,从中我们可以学到非常多的技巧,本文来学习一下宏技巧,文章有点长,但耐心看完后C语言level直接飙升。 本文出自:大叔的嵌入式小站,一个简单的嵌入式/单片机学习、交流小站 从…

机器看世界

博主简介 博主是一名大二学生,主攻人工智能研究。感谢让我们在CSDN相遇,博主致力于在这里分享关于人工智能,c,Python,爬虫等方面知识的分享。 如果有需要的小伙伴可以关注博主,博主会继续更新的&#xff0c…

为什么红黑树如此受欢迎

平衡二叉查找树有很多,但是我们一提到平衡二叉查找树,常提及的就是红黑树,它的“出镜率”甚至要高于平衡二叉查找树。 红黑树是一种相对平衡的二叉查找树,不符合严格意义上平衡二叉查找树的定义。 目录 红黑树的插入 红黑树的验…

SAP ABAP WebService

第一步:SE37 创建一个远程函数(Remote Function Module)注意该函数需要将Remote Enable开启第二步:创建WebService首先:SE37 打开需要关联的函数在菜单 Utilities->More Utilities->Create Web Service->From…

二 Go的基本语法

1. 基本类型 boolstringint、int8、int16、int32、int64uint、uint8、uint16、uint32、uint64、uintptrbyte // uint8 的别名rune // int32 的别名 代表一个 Unicode 码float32、float64complex64、complex128 2. 三种声明变量 2.1 标准格式 var name type 其中,…

MyBatis-Plus联表查询的短板,该如何解决呢

mybatis-plus作为mybatis的增强工具,它的出现极大的简化了开发中的数据库操作,但是长久以来,它的联表查询能力一直被大家所诟病。一旦遇到left join或right join的左右连接,你还是得老老实实的打开xml文件,手写上一大段…

链表及其基本操作

1.单链表:1.1定义/性质:链表是线性表的链式存储方式。单链表通过指针线性遍历,删除/增加节点时间复杂度为O(1),访问节点时间复杂度为O(n)。单链表分为带头结点和不带头结点两种,带头结点是为了方便统一操作&#xff08…

数据结构:链式二叉树初阶

目录 一.链式二叉树的逻辑结构 1.链式二叉树的结点结构体定义 2.链式二叉树逻辑结构 二.链式二叉树的遍历算法 1.前序遍历 2.中序遍历 3.后序遍历 4.层序遍历(二叉树非递归遍历算法) 层序遍历概念: 层序遍历算法实现思路: 层序遍历代码实现: 三.链式二叉树遍历算…

蓝桥杯三月刷题 第六天

文章目录💥前言😉解题报告💥星期计算🤔一、思路:😎二、代码:💥考勤刷卡🤔一、思路:😎二、代码:💥卡片🤔一、思路:😎二、代…

Spring SpringBoot中使用Mybatis-plusDemo1

官网:https://baomidou.com GitHub:GitHub - baomidou/mybatis-plus: An powerful enhanced toolkit of MyBatis for simplify development Gitee:mybatis-plus: mybatis 增强工具包,简化 CRUD 操作。 文档 http://baomidou.com低代码组件库 http://aizuda.com My…

Leetcode.剑指 Offer II 023. 两个链表的第一个重合节点

题目链接 Leetcode.剑指 Offer II 023. 两个链表的第一个重合节点 easy 题目描述 给定两个单链表的头节点 headA和 headB,请找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null。 注意,函数返回结果后,链表必…

Lumion 2023即将上线,低配电脑如何驾驭Lumion

年更选手Lumion的更新速度“从不让人失望”,自从Lumion 12更新完之后,官方意料之中的没了动静。但是就在这几天,官方终于放出了首支Lumion 2023的更新预告,并且宣布将于本月中旬发布!Lumion 2023主要变化是支持光线追踪…

【Linux:环境变量的理解】

目录 1 Z(zombie)-僵尸进程 2 孤儿进程 3 环境变量 3.1 基本概念 3.2 测试HOME 3.3 和环境变量相关的命令 3.4 环境变量的组织方式 3.5 环境变量通常是具有全局属性的 在讲环境变量之前,我们先把上次遗留知识点给总结了(僵尸进程和孤儿进程&…

fast-api 一款快速将spring的bean发布成接口并生产对应swagger文档调试的轻量级工具

fast-api简介背景开发痛点:分析需求实战fast-api快速上手1. 引入依赖2. FastApiMapping标记service对象3. swagger2/knife4j 在线测试进阶使用开启调试模式支持指定类或包目录发布如何关闭fast-api自定义fast-api的前缀写在最后简介 fast-api 一款快速将spring的bean(service)发…

案例学习6-没有复用思想

背景: 上述两个方法查询同一张表,只是数据结构不同,完全可以合成一份方法,减少代码冗余。 实现效果如下 不传参,查询所有的数据 传入特定参数实现按条件查询: 实现方式: GetMapping(value &q…