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

【前端】前端浏览器性能优化的小方法

前端浏览器性能优化是一个系统工程,涵盖了从加载到渲染的各个环节。以下是全面的优化方案:

一、资源加载优化

1. 减少HTTP请求

// 使用雪碧图 CSS Sprites
.icon {background-image: url('sprite.png');background-position: -0px -20px;
}// 内联小图片(Base64)
.logo {background: url('...');
}

2. 资源压缩与优化

<!-- 压缩资源 -->
<script src="app.min.js"></script>
<link rel="stylesheet" href="style.min.css"><!-- WebP格式图片 -->
<picture><source srcset="image.webp" type="image/webp"><source srcset="image.jpg" type="image/jpeg"><img src="image.jpg" alt="示例图片">
</picture>

3. 缓存策略

// Service Worker 缓存
self.addEventListener('fetch', (event) => {event.respondWith(caches.match(event.request).then(response => response || fetch(event.request)));
});

二、JavaScript 优化

1. 代码分割与懒加载

// 动态导入 - Webpack
const module = await import('./module.js');// React.lazy
const LazyComponent = React.lazy(() => import('./LazyComponent'));// 路由级别代码分割
const Home = lazy(() => import('./pages/Home'));
const About = lazy(() => import('./pages/About'));

2. 防抖与节流

// 防抖
function debounce(func, wait) {let timeout;return function executedFunction(...args) {const later = () => {clearTimeout(timeout);func(...args);};clearTimeout(timeout);timeout = setTimeout(later, wait);};
}// 节流
function throttle(func, limit) {let inThrottle;return function(...args) {if (!inThrottle) {func.apply(this, args);inThrottle = true;setTimeout(() => inThrottle = false, limit);}};
}// 使用
window.addEventListener('resize', throttle(handleResize, 250));
searchInput.addEventListener('input', debounce(handleSearch, 300));

3. 事件委托

// 不好的做法
document.querySelectorAll('.item').forEach(item => {item.addEventListener('click', handleClick);
});// 好的做法 - 事件委托
document.getElementById('list').addEventListener('click', (event) => {if (event.target.classList.contains('item')) {handleClick(event);}
});

三、CSS 优化

1. 选择器性能

/* 不好的选择器 */
div#container ul li a { ... }/* 好的选择器 */
.nav-link { ... }/* 避免重排重绘 */
.transform-element {transform: translateX(100px); /* 使用合成层 */will-change: transform; /* 提示浏览器 */
}

2. 关键CSS内联

<head><style>/* 关键CSS内联 */.header { position: fixed; top: 0; }.hero { height: 100vh; }</style>
</head>

四、渲染性能优化

1. 虚拟列表

// 大数据列表优化
function VirtualList({ items, itemHeight, containerHeight }) {const [scrollTop, setScrollTop] = useState(0);const visibleStart = Math.floor(scrollTop / itemHeight);const visibleEnd = Math.min(visibleStart + Math.ceil(containerHeight / itemHeight) + 1,items.length);const visibleItems = items.slice(visibleStart, visibleEnd);return (<div style={{ height: containerHeight, overflow: 'auto' }}onScroll={(e) => setScrollTop(e.target.scrollTop)}><div style={{ height: items.length * itemHeight, position: 'relative' }}>{visibleItems.map((item, index) => (<divkey={visibleStart + index}style={{position: 'absolute',top: (visibleStart + index) * itemHeight,height: itemHeight}}>{item.content}</div>))}</div></div>);
}

2. 使用 Web Workers

// main.js
const worker = new Worker('worker.js');worker.postMessage({ data: largeData });worker.onmessage = (event) => {console.log('Result:', event.data);
};// worker.js
self.onmessage = function(event) {const result = heavyCalculation(event.data);self.postMessage(result);
};

五、网络优化

1. 资源预加载

<!-- DNS 预解析 -->
<link rel="dns-prefetch" href="//api.example.com"><!-- 预加载关键资源 -->
<link rel="preload" href="critical-font.woff2" as="font" type="font/woff2" crossorigin>
<link rel="preload" href="hero-image.jpg" as="image"><!-- 预连接 -->
<link rel="preconnect" href="https://cdn.example.com">

2. CDN 与 HTTP/2

<!-- 使用CDN -->
<script src="https://cdn.example.com/react@18/umd/react.production.min.js"></script><!-- HTTP/2 服务器推送 -->
<!-- 在服务器配置 -->

六、监控与性能测量

1. Performance API

// 性能测量
const measurePageLoad = () => {const [navigation] = performance.getEntriesByType('navigation');console.log('TTFB:', navigation.responseStart - navigation.requestStart);console.log('DOM Content Loaded:', navigation.domContentLoadedEventEnd - navigation.fetchStart);console.log('Full Load:', navigation.loadEventEnd - navigation.fetchStart);
};// 用户关键指标
const observer = new PerformanceObserver((list) => {for (const entry of list.getEntries()) {console.log('LCP:', entry.startTime);}
});
observer.observe({ entryTypes: ['largest-contentful-paint'] });

2. 真实用户监控 (RUM)

// Core Web Vitals
import { getCLS, getFID, getFCP, getLCP, getTTFB } from 'web-vitals';getCLS(console.log);
getFID(console.log);
getLCP(console.log);

七、现代优化技术

1. 图片懒加载

<img src="placeholder.jpg" data-src="real-image.jpg" loading="lazy"alt="示例图片"class="lazyload"
>
// 交叉观察器实现懒加载
const lazyImages = document.querySelectorAll('img.lazyload');const imageObserver = new IntersectionObserver((entries, observer) => {entries.forEach(entry => {if (entry.isIntersecting) {const img = entry.target;img.src = img.dataset.src;img.classList.remove('lazyload');imageObserver.unobserve(img);}});
});lazyImages.forEach(img => imageObserver.observe(img));

2. 预渲染和SSG

// Next.js 静态生成
export async function getStaticProps() {const data = await fetchData();return {props: { data },revalidate: 60 // ISR: 60秒重新生成};
}

八、构建工具优化

Webpack 配置示例

// webpack.config.js
module.exports = {optimization: {splitChunks: {chunks: 'all',cacheGroups: {vendor: {test: /[\\/]node_modules[\\/]/,name: 'vendors',chunks: 'all',},},},},plugins: [new BundleAnalyzerPlugin(),new CompressionPlugin({algorithm: 'gzip',}),],
};

这些优化措施需要根据具体项目情况选择实施,建议使用 Lighthouse 等工具定期检测性能,持续优化。

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

相关文章:

  • google广告联盟网站服务平台型网站
  • Android GPU的RenderThread Texture upload上传Bitmap优化prepareToDraw
  • 10.1 网络规划与设计——结构化布线系统
  • 国产麒麟、uos在线编辑数据库中的文件
  • 从零开始的C++学习生活 15:哈希表的使用和封装unordered_map/set
  • 【图像处理基石】通过立体视觉重建建筑高度:原理、实操与代码实现
  • 金融培训网站源码国内可以做的国外兼职网站
  • 东莞网站设计制作网站个人网页设计需求分析
  • 率先发布!浙人医基于KingbaseES构建多院区异构多活容灾新架构
  • CSS 样式用法大全
  • Chrome旧版本下载
  • 浙江省建设网站首页html网站源代码
  • 厦门行业网站建设怎样建立自己的销售网站
  • 网站建设丿选择金手指排名15企业网站的制作公司
  • 结合MAML算法元强化学习
  • 重组蛋白表达的几种类型介绍
  • STM32之TM1638数码管及键盘驱动
  • Windows 10 安装 Docker Desktop
  • 数据的存储
  • GJOI 10.20/10.22 题解
  • Linux:权限(完结)|权限管理|修改权限chmod chown charp|文件类型|拓展
  • (一)仓库创建与配置 - .git 目录的结构与作用
  • Office 2010 64位 补丁 officesp2010-kb2687455 安装步骤详解(附安装包)
  • 建免费网站建设银行网站能不能注销卡
  • springboot中的怎么用JUnit进行测试的?
  • LeetCode:695. 岛屿的最大面积
  • 传奇手游可以使用云手机挂机搬砖吗
  • 2025 OSCAR丨与创新者同频!Apache RocketMQ 邀您共赴开源之约
  • Dify配置本地部署的音频识别模型
  • C# .NET Core中Chart图表绘制与PDF导出