首页性能优化
首页性能提升是前端优化中的核心任务之一,因为首页是用户访问的第一入口,其加载速度和交互体验直接影响用户的留存率和转化率。
1. 性能瓶颈分析
在优化之前,首先需要通过工具分析首页的性能瓶颈。常用的工具包括:
- Chrome DevTools:查看网络请求、JavaScript 执行时间、渲染性能等。
- Lighthouse:提供全面的性能评分和改进建议。
- WebPageTest:分析页面加载的详细时间线。
常见的性能瓶颈包括:
- 过大的资源文件(如图片、JavaScript、CSS)。
- 过多的网络请求。
- 未优化的 JavaScript 执行逻辑。
- 渲染阻塞(如未压缩的 CSS 或未异步加载的 JavaScript)。
2. 优化策略与代码实现
2.1 减少资源体积
2.1.1 压缩 JavaScript 和 CSS
使用工具(如 Webpack、Vite)对 JavaScript 和 CSS 进行压缩。
// webpack.config.js
const TerserPlugin = require('terser-webpack-plugin');
const CssMinimizerPlugin = require('css-minimizer-webpack-plugin');module.exports = {optimization: {minimizer: [new TerserPlugin(), // 压缩 JavaScriptnew CssMinimizerPlugin(), // 压缩 CSS],},
};
2.1.2 图片优化
- 使用现代图片格式(如 WebP)。
- 压缩图片大小。
<picture><source srcset="image.webp" type="image/webp"><img src="image.jpg" alt="Fallback image">
</picture>
2.1.3 Tree Shaking
移除未使用的代码。
// webpack.config.js
module.exports = {mode: 'production',optimization: {usedExports: true, // 启用 Tree Shaking},
};
2.2 减少网络请求
2.2.1 合并文件
将多个小文件合并为一个大文件,减少 HTTP 请求次数。
// webpack.config.js
module.exports = {entry: './src/index.js', // 入口文件output: {filename: 'bundle.js', // 输出文件},
};
2.2.2 使用 HTTP/2
HTTP/2 支持多路复用,可以减少请求的开销。
# Nginx 配置
server {listen 443 ssl http2;server_name example.com;
}
2.2.3 使用 CDN
将静态资源托管到 CDN,加速资源加载。
<script src="https://cdn.example.com/react.production.min.js"></script>
2.3 优化 JavaScript 执行
2.3.1 异步加载 JavaScript
使用 async 或 defer 属性避免阻塞渲染。
<script src="app.js" async></script>
<script src="app.js" defer></script>
2.3.2 代码分割(Code Splitting)
按需加载 JavaScript 代码。
// React 中使用 React.lazy 和 Suspense
import React, { lazy, Suspense } from 'react';
const LazyComponent = lazy(() => import('./LazyComponent'));function App() {return (<Suspense fallback={<div>Loading...</div>}><LazyComponent /></Suspense>);
}
2.3.3 避免长任务
将长时间运行的 JavaScript 任务拆分为多个小任务。
// 使用 requestIdleCallback 拆分任务
function processTask() {if (tasks.length > 0) {requestIdleCallback((deadline) => {while (deadline.timeRemaining() > 0 && tasks.length > 0) {const task = tasks.shift();task();}if (tasks.length > 0) {processTask();}});}
}
2.4 优化 CSS
2.4.1 避免阻塞渲染
将关键 CSS 内联到 HTML 中,非关键 CSS 异步加载。
<style>/* 关键 CSS */body { font-family: Arial, sans-serif; }
</style>
<link rel="stylesheet" href="non-critical.css" media="print" onload="this.media='all'">
2.4.2 减少 CSS 选择器复杂度
避免使用过于复杂的选择器。
/* 不推荐 */
div.container > ul.list > li.item { ... }/* 推荐 */
.item { ... }
2.5 优化渲染性能
2.5.1 减少重排和重绘
避免频繁操作 DOM。
// 不推荐
for (let i = 0; i < 100; i++) {element.style.width = `${i}px`;
}// 推荐
const width = element.offsetWidth;
requestAnimationFrame(() => {element.style.width = `${width + 100}px`;
});
2.5.2 使用虚拟 DOM
在框架(如 React、Vue)中使用虚拟 DOM 减少直接操作真实 DOM 的开销。
// React 示例
function App() {const [count, setCount] = React.useState(0);return (<div><p>{count}</p><button onClick={() => setCount(count + 1)}>Increment</button></div>);
}
2.6 缓存优化
2.6.1 使用 Service Worker
通过 Service Worker 缓存资源,实现离线访问。
// service-worker.js
self.addEventListener('install', (event) => {event.waitUntil(caches.open('v1').then((cache) => {return cache.addAll(['/', '/index.html', '/styles.css', '/app.js']);}));
});self.addEventListener('fetch', (event) => {event.respondWith(caches.match(event.request).then((response) => {return response || fetch(event.request);}));
});
2.6.2 设置 HTTP 缓存头
通过缓存头减少重复请求。
# Nginx 配置
location ~* \.(js|css|png|jpg|jpeg|gif|ico)$ {expires 1y;add_header Cache-Control "public";
}
3. 性能监控与持续优化
- 使用 Lighthouse 定期检查首页性能。
- 使用 Sentry 监控 JavaScript 错误。
- 使用 Google Analytics 分析用户行为。
4. 总结
首页性能提升需要从资源加载、JavaScript 执行、CSS 优化、渲染性能等多个方面入手。通过减少资源体积、优化网络请求、异步加载、代码分割、缓存优化等手段,可以显著提升首页的加载速度和用户体验。同时,持续监控和优化是确保性能长期稳定的关键。
相关文章:
首页性能优化
首页性能提升是前端优化中的核心任务之一,因为首页是用户访问的第一入口,其加载速度和交互体验直接影响用户的留存率和转化率。 1. 性能瓶颈分析 在优化之前,首先需要通过工具分析首页的性能瓶颈。常用的工具包括: Chrome DevTo…...
使用usb-cam包时填充摄像头参数话题
问题描述: 在启动usb摄像头之后,像apriltag_ros等包需要读取摄像头的内参信息,但是usb-cam默认是没有内参信息发布的,需要自己填写或标定。 解决方案: 如果你有内参数据或者急于验证后续代码的逻辑正确性,…...
pandas学习笔记(一)——基础知识和应用案例
pandas学习笔记 基础语法参考菜鸟教程:https://www.runoob.com/pandas/pandas-tutorial.html # jupyter import pandas as pd import matplotlib from matplotlib import pyplot as plt import numpy as npmatplotlib.use(TkAgg)data {timestamp: [1, 2, 3, 4, 5…...
SpringBoot + Mybatis Plus 整合 Redis
Redis 在用户管理系统中的典型应用场景 结合你的用户增删改查接口,以下是 Redis 的实用场景和具体实现方案: 场景作用实现方案用户信息缓存减少数据库压力,加速查询响应使用 Spring Cache Redis 注解缓存登录 Token 存储分布式 Session 或…...
【AI 大模型】RAG 检索增强生成 ⑤ ( 向量数据库 | 向量数据库 索引结构和搜索算法 | 常见 向量数据库 对比 | 安装并使用 向量数据库 chromadb 案例 )
文章目录 一、向量数据库1、向量数据库引入2、向量数据库简介3、向量数据库 索引结构和搜索算法4、向量数据库 应用场景5、传统数据库 与 向量数据库 对比 二、常见 向量数据库 对比三、向量数据库 案例1、安装 向量数据库 chromadb2、核心要点 解析① 创建数据库实例② 创建数…...
解决single cell portal点击下载但跳转的是网页
Single cell RNA-seq of Tmem100-lineage cells in a mouse model of osseointegration - Single Cell Portal 想下载个小鼠数据集: 点击下载跳转为网页: 复制bulk download给的链接无法下载 bulk download给的原链接: curl.exe "http…...
基于 Prometheus + Grafana 监控微服务和数据库
以下是基于 Prometheus Grafana 监控微服务和数据库的详细指南,包含架构设计、安装配置及验证步骤: 一、整体架构设计 二、监控微服务 1. 微服务指标暴露 Spring Boot 应用: xml <!-- 添加 Micrometer 依赖 --> <dependency>…...
GitHub Copilot 在 VS Code 上的终极中文指南:从安装到高阶玩法
GitHub Copilot 在 VS Code 上的终极中文指南:从安装到高阶玩法 前言 GitHub Copilot 作为 AI 编程助手,正在彻底改变开发者的编码体验。本文将针对中文开发者,深度解析如何在 VS Code 中高效使用 Copilot,涵盖基础设置、中文优化…...
为什么选择 Rust 和 WebAssembly?
一、低级控制与高级体验 在 Web 应用开发中,JavaScript 虽然灵活,但往往难以保证稳定的性能。其动态类型系统和垃圾回收(GC)机制会导致性能波动,甚至在不经意间因偏离 JIT(即时编译器)的最佳路…...
Vala语言基础知识-源文件和编译
源文件和编译 Vala代码以.vala为扩展名。与Java等语言不同,Vala不强制要求严格的文件结构——它没有类似Java的"包"(package)或"类文件"(class file)的概念,而是通过文件内的文本…...
CAN总线的CC帧和FD帧之间如何仲裁
为满足CAN总线日益提高的带宽需求,博世公司于2012年推出CAN FD(具有灵活数据速率的CAN)标准,国际标准化组织(ISO)2015年通过ISO 11898-1:2015标准,正式将CAN FD纳入国际标准,以示区别…...
SpringBoot 第一课(Ⅲ) 配置类注解
目录 一、PropertySource 二、ImportResource ①SpringConfig (Spring框架全注解) ②ImportResource注解实现 三、Bean 四、多配置文件 多Profile文件的使用 文件命名约定: 激活Profile: YAML文件支持多文档块ÿ…...
Python的类和对象(4)
1、反射 动态的给类和对象添加属性,获取属性,删除属性,修改属性【反射】。 --4个内置函数 1)设置属性:setattr( 对象/类,属性名,属性值) 2)获取属性:getattr(对象/类&am…...
使用EasyExcel进行简单的导入、导出
准备 在pom.xml添加依赖 <!-- EasyExcel --><dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.1.1</version></dependency>导入 controller // 用户导入Operation(summary…...
Excel(函数篇):COUNTIF与CONUTIFS函数、SUMIF与SUMIFS函数、ROUND函数、MATCH与INDEX函数、混合引用与条件格式
目录 COUNTIF和COUNTIFS函数COUNTIF函数COUNTIFS函数SUMIF和SUMIFS函数SUMIF函数SUMIFS函数SUMIFS函数与控件实现动态年月汇总ROUND、ROUNDUP、ROUNDDOWN函数单元格混合引用条件格式与公式,标记整行数据MATCH和INDEX函数COUNTIF和COUNTIFS函数 COUNTIF函数 统计下“苏州”出现…...
虚拟定位 1.2.0.2 | 虚拟定位,上班打卡,校园跑步模拟
Fake Location是一款运行于安卓平台上的功能强大、简单实用的虚拟定位软件。它能够帮助用户自定义位置到地图上的任意地方,以ROOT环境运行不易被检测,同时也支持免ROOT运行。提供路线模拟、步频模拟、WIFI模拟等方式,支持反检测。 大小&…...
【最大异或和——可持久化Trie】
题目 代码 #include <bits/stdc.h> using namespace std;const int N 6e510; //注意这里起始有3e5,又可能插入3e5 const int M N * 25;int rt[N], tr[M][2]; //根,trie int idx, cnt, br[M]; //根分配器,点分配器,点的相…...
C# WPF编程-启动新窗口
C# WPF编程-启动新窗口 新建窗口: 工程》添加》窗口 命名并添加新的窗口 这里窗口名称为Window1.xaml 启动新窗口 Window1 win1 new Window1(); win1.Show(); // 非模态启动窗口win1.ShowDialog(); // 模态启动窗口 模态窗口:当一个模态窗口被打开时&a…...
数据库:MySQL 指令大全(备忘清单)
文章目录 入门介绍登录MySQL常用的数据库 Database表 TableProccess 查看 MySQL 信息退出MySQL会话备份 MySQL 示例管理表格从表中查询数据从多个表查询使用 SQL 约束修改数据管理视图管理触发器WHENEVENTTRIGGER_TYPE 管理索引 MySQL 数据类型StringsDate & timeNumeric 函…...
NET进行CAD二次开发之二
本文主要针对CAD 二次开发入门与实践:以 C# 为例_c# cad-CSDN博客的一些实践问题做一些补充。 一、DLL介绍 在 AutoCAD 中,accoremgd.dll、acdbmgd.dll 和 acmgd.dll 都是与.NET API 相关的动态链接库,它们在使用.NET 语言(如 C#、VB.NET)进行 AutoCAD 二次开发时起着关…...
Python 实现大文件的高并发下载
项目背景 基于一个 scrapy-redis 搭建的分布式系统,所有item都通过重写 pipeline 存储到 redis 的 list 中。这里我通过代码演示如何基于线程池 协程实现对 item 的中文件下载。 Item 结构 目的是为了下载 item 中 attachments 保存的附件内容。 {"crawl_tim…...
【最新】 ubuntu24安装 1panel 保姆级教程
系统:ubuntu24.04.1 安装软件 :1panel 第一步:更新系统 sudo apt update sudo apt upgrade 如下图 第二步:安装1panel,运行如下命令 curl -sSL https://resource.fit2cloud.com/1panel/package/quick_start.sh -o …...
c++图论(二)之图的存储图解
在 C 中实现图的存储时,常用的方法包括 邻接矩阵(Adjacency Matrix)、邻接表(Adjacency List) 和 边列表(Edge List)。以下是具体实现方法、优缺点分析及代码示例: 1. 邻接矩阵&…...
c++图论(一)之图论的起源和图的概念
C 图论之图论的起源和图的概念 图论(Graph Theory)是数学和计算机科学中的一个重要分支,其起源可以追溯到 18 世纪 的经典问题。以下是图论的历史背景、核心起源问题及其与基本概念和用途: 借用一下CSDN的图片哈 一、图论的起源&…...
《Python深度学习》第二讲:深度学习的数学基础
本讲来聊聊深度学习的数学基础。 深度学习听起来很厉害,其实它背后是一些很有趣的数学原理。本讲会用简单的方式解释这些原理,还会用一些具体的例子来帮助你理解。 2.1 初识神经网络 先从一个简单的任务开始:识别手写数字。 想象一下,你有一堆手写数字的图片,你想让计算…...
ChatGPT and Claude国内使用站点
RawChat kelaode chatgptplus chatopens(4.o mini免费,plus收费) 网页: 定价: wildcard 网页: 虚拟卡定价: 2233.ai 网页: 定价: MaynorAPI chatgpt cla…...
进行性核上性麻痹:精心护理,点亮希望之光
进行性核上性麻痹是一种罕见的神经退行性疾病,严重影响患者的生活质量。有效的健康护理能够在一定程度上缓解症状、延缓病情发展,给患者带来更好的生活体验。 在日常生活护理方面,由于患者平衡能力逐渐下降,行动不便,居…...
ZED X系列双目3D相机的耐用性与创新设计解析
在工业自动化和学术研究领域,高精度的视觉设备正成为提升效率和质量的关键。ZED X系列AI立体相机,凭借其先进的技术和耐用的设计,为这一领域带来了新的可能。 核心技术:深度感知与精准追踪 ZED X系列的核心技术之一是Neural Dept…...
HarmonyOS三层架构实战
目录: 1、三层架构项目结构1.0、三层架构简介1.1、 common层(主要放一些公共的资源等)1.2、 features层(主要模块定义的组件以及图片等静态资源)1.3、 products层(主要放主页面层和一些主要的资源ÿ…...
计算机四级 - 数据库原理 - 第4章 「关系数据库标准语言SQL」
4.1 SQL概述 4.1.1 结构化查询语言SQL SQL(Structured Query Language)称为结构化查询语言,它是由1974年由Boyce和Chamberi提出的,1975年至1979年IBM公司的San Jose Research Laboratory研制了关系数据库管理系统的原型系统System R,并实现了这种语198…...
