网站性能不佳?试试这十大前端性能优化技巧!(一)

简介: 网站性能不佳?试试这十大前端性能优化技巧!

1. 减少 HTTP 请求的数量和大小,合并、压缩、缓存静态资源,避免重复请求和无用请求。

以下是一个使用 Node.jsGulp 自动化构建工具来合并、压缩和缓存静态资源的示例:

1. 安装 Gulp 和相关依赖:

$ npm install gulp gulp-concat gulp-uglify gulp-rename gulp-cache

2. 在项目目录下创建 gulpfile.js 文件,开始配置:

const gulp = require('gulp');
const concat = require('gulp-concat');
const uglify = require('gulp-uglify');
const rename = require('gulp-rename');
const cache = require('gulp-cache');
// 合并、压缩、重命名 js
gulp.task('scripts', function () {
  return gulp.src('src/js/*.js')
    .pipe(concat('main.js'))
    .pipe(gulp.dest('dist/js'))
    .pipe(rename({suffix: '.min'}))
    .pipe(uglify())
    .pipe(gulp.dest('dist/js'))
});
// 缓存静态资源
gulp.task('cache', function() {
  return gulp.src('src/**/*.{js,css,png,jpeg,gif,svg}')
    .pipe(cache())
    .pipe(gulp.dest('dist'))
});
// 监听文件变化
gulp.task('watch', function () {
  gulp.watch('src/js/*.js', gulp.series('scripts'));
  gulp.watch('src/**/*.{js,css,png,jpeg,gif,svg}', gulp.series('cache'));
});
// 执行所有任务
gulp.task('default', gulp.parallel(['scripts', 'cache', 'watch']));

3. 运行 Gulp 自动化构建工具:

$ gulp

4. 完成后,合并、压缩、重命名后的静态资源将会保存到 dist 目录下,可以直接通过 HTML 中引用来使用它们。

通过上述代码案例,我们可以使用 Gulp 自动化构建工具对静态资源进行合并、压缩和缓存,有效地减少 HTTP 请求的数量和大小,避免重复请求和无用请求,优化网页性能和用户体验。

2. 减少 JavaScript 和 CSS 文件的大小和数量,避免不必要的代码。

以下是一个使用 WebpackBabel 来减少 JavaScript 文件大小和数量的示例:

1. 安装 Webpack 和相关依赖:

$ npm install webpack webpack-cli webpack-dev-server babel-loader @babel/core @babel/preset-env

2. 创建一个 src 目录并添加 index.js 文件和 styles.css 文件:

// index.js
const sum = (a, b) => a + b;
console.log(sum(2, 2));
// styles.css
body {
  background-color: #f0f0f0;
}

3. 在项目目录下创建 webpack.config.js 文件,开始配置:

const path = require('path');
module.exports = {
  entry: './src/index.js',
  output: {
    filename: 'main.js',
    path: path.resolve(__dirname, 'dist'),
  },
  module: {
    rules: [
      {
        test: /\.js$/,
        exclude: /node_modules/,
        use: {
          loader: 'babel-loader',
          options: {
            presets: ['@babel/preset-env']
          }
        }
      },
      {
        test: /\.css$/,
        use: ['style-loader', 'css-loader'],
      },
    ],
  },
};

4. 在 package.json 中添加命令:

"scripts": {
  "build": "webpack",
  "dev": "webpack-dev-server --open"
},

5. 运行构建命令:

$ npm run build

6. 完成后,输出的 main.js 文件大小将会更小,不必要的代码已经被自动去除。

通过使用 WebpackBabel 实现 JavaScript 文件的压缩和精简,可以有效减少文件大小和数量,提升网页性能和用户体验。类似的,使用类似 CSS Nano 的工具可以对 CSS 文件进行压缩和精简,也可以进一步减少文件大小和数量。

3. 使用浏览器缓存避免重复请求。可以使用强缓存和协商缓存配合使用。

以下是一个使用 Express.jsETag 缓存协商来减少不必要的请求的示例:

1. 安装 Express.js 和相关依赖:

$ npm install express ejs

2. 在项目目录下创建 app.js 文件,开始配置:

const express = require('express');
const ejs = require('ejs');
const app = express();
// 设置 EJS 模板引擎
app.set('views', './views');
app.set('view engine', 'ejs');
// 定义路由
app.get('/', (req, res) => {
  // 设置强缓存
  res.setHeader('Cache-Control', 'public, max-age=60, immutable');
  // 生成 ETag
  const content = `
    <h1>Hello, World!</h1>
    <p>This is a simple web page.</p>
  `;
  const hash = require('crypto').createHash('md5').update(content).digest('base64');
  const etag = `"${hash}"`;
  // 判断 ETag 是否匹配
  if (etag === req.headers['if-none-match']) {
    // 返回 304 Not Modified
    res.status(304).end();
  } else {
    // 返回页面内容和 ETag
    res.setHeader('ETag', etag);
    res.render('index', { content });
  }
});
// 启动服务器
app.listen(3000, () => {
  console.log('Server is running at http://localhost:3000');
});

3. 在 views 目录下创建一个 index.ejs 模板文件:

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>My Web Page</title>
</head>
<body>
  <%- content %>
</body>
</html>

4. 运行 Node.js 服务器:

$ node app.js

5. 访问 http://localhost:3000,页面内容会被缓存,除非 ETag 发生变化,否则客户端会从缓存中加载。

通过使用强缓存和 ETag 缓存协商机制,可以在服务器端避免不必要的请求,减少带宽消耗和页面加载时间,优化网页性能和用户体验。

4. 延迟加载图片和视频,使用图片和视频懒加载技术,只在需要时加载文件。

好的,以下是一个使用 Intersection Observer API 实现图片懒加载的示例:

1. 在 HTML 中标记需要延迟加载的图片,使用 data-src 属性替代 src 属性:

<img data-src="image.jpg" alt="My Image">

2. 在 CSS 中定义占位符样式,确保页面布局不会因未加载的图片而发生变化:

img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  background-color: #f0f0f0;
}

3. 在 JavaScript 中使用 Intersection Observer API 监视图片元素是否进入视口:

const images = document.querySelectorAll('img[data-src]');
const options = {
  rootMargin: '0px',
  threshold: 0.1
};
const observer = new IntersectionObserver(entries => {
  entries.forEach(entry => {
    if (entry.isIntersecting) {
      const img = entry.target;
      const src = img.getAttribute('data-src');
      img.setAttribute('src', src);
      img.removeAttribute('data-src');
      observer.unobserve(img);
    }
  });
}, options);
images.forEach(img => {
  observer.observe(img);
});

4. 运行页面,当图片元素进入视口时,data-src 属性将会被替换成真正的 src 属性,图片将会被加载。

通过使用 Intersection Observer API 实现图片懒加载,可以延迟加载页面中的图片和视频,提高页面加载速度和用户体验,减少带宽消耗和服务器负载。


网站性能不佳?试试这十大前端性能优化技巧!(二)https://developer.aliyun.com/article/1426477

相关文章
|
6月前
|
机器学习/深度学习 前端开发 算法
利用深度学习技术提升前端图像处理性能
本文将探讨如何利用深度学习技术在前端图像处理中提升性能。通过结合深度学习算法和前端技术,我们可以实现更高效的图像处理功能,提升用户体验和系统性能。
|
6月前
|
前端开发 数据可视化 JavaScript
前端vite+vue3——可视化页面性能耗时指标(fmp、fp)
前端vite+vue3——可视化页面性能耗时指标(fmp、fp)
262 6
|
6月前
|
缓存 前端开发 JavaScript
前端性能优化:高在性能,大在范围,必要前置知识一网打尽!(下)
在上一篇 前端性能优化:高在性能,大在范围,必要前置知识一网打尽!(上) 一文中介绍了和前端性能优化相关的一些前置知识,那么本篇就针对优化方案进行总结,核心的方向还是上篇文章中提到的内容:
|
6月前
|
缓存 前端开发 JavaScript
如何优化前端页面性能
前端性能优化是网站开发中非常重要的一部分,它直接关系到用户体验和网站的流量以及排名。本文将介绍一些优化前端页面性能的方法,包括减少HTTP请求、压缩代码、使用CDN等。
|
6月前
|
前端开发 Android开发 iOS开发
【Flutter前端技术开发专栏】Flutter在Android与iOS上的性能对比
【4月更文挑战第30天】Flutter 框架实现跨平台移动应用,通过一致的 UI 渲染(Skia 引擎)、热重载功能和响应式框架提高开发效率和用户体验。然而,Android 和 iOS 的系统差异、渲染机制及编译过程影响性能。性能对比显示,iOS 可能因硬件优化提供更流畅体验,而 Android 更具灵活性和广泛硬件支持。开发者可采用代码、资源优化和特定平台优化策略,利用性能分析工具提升应用性能。
268 0
【Flutter前端技术开发专栏】Flutter在Android与iOS上的性能对比
|
3月前
|
缓存 前端开发 JavaScript
超时空加速秘籍:揭秘JavaScript前端开发中的性能魔法,让您的Web应用瞬间穿越到未来!
【8月更文挑战第27天】本文介绍了一系列实用的JavaScript性能优化方法并提供了示例代码,包括减少DOM操作、使用事件委托、避免阻塞主线程、异步加载资源、利用浏览器缓存、代码分割以及使用Service Worker等技术,帮助开发者有效提升Web应用性能和用户体验。
49 2
|
3月前
|
缓存 编解码 前端开发
优化Web应用性能的前端技巧:从加载时间到用户体验
在现代Web开发中,提升前端性能不仅仅是为了缩短页面加载时间,更是为了提供更流畅的用户体验。本文将探讨几种有效的前端优化技术,包括懒加载、代码拆分、资源压缩以及浏览器缓存策略。通过具体实例和最佳实践,读者将能够掌握如何系统地提高Web应用的响应速度,减少资源消耗,并最终改善用户的整体体验。
|
3月前
|
前端开发 JavaScript API
一场前端框架的“武林大会”,三大主流框架之间的性能比较!!!
一场前端框架的“武林大会”,三大主流框架之间的性能比较!!!
|
3月前
|
前端开发 UED 开发者
React组件优化全攻略:深度解析让你的前端应用飞速运行的秘诀——从PureComponent到React.memo的彻底性能比较
【8月更文挑战第31天】在构建现代Web应用时,性能是提升用户体验的关键因素。React作为主流前端库,其组件优化尤为重要。本文深入探讨了React组件优化策略,包括使用`PureComponent`、`React.memo`及避免不必要的渲染等方法,帮助开发者显著提升应用性能。通过实践案例对比优化前后效果,不仅提高了页面渲染速度,还增强了用户体验。优化React组件是每个开发者必须关注的重点。
63 0
|
3月前
|
前端开发 JavaScript 开发者
掌握Web前端事件处理精髓:从事件冒泡到事件委托,轻松优化你的交互体验与代码性能!
【8月更文挑战第23天】在Web前端开发中,事件处理是实现用户交互的关键机制。其中,事件冒泡与事件委托是优化页面性能、简化代码的重要手段。事件冒泡是指事件从触发它的元素开始,沿着DOM树向上逐层传播至根节点的过程。通过阻止事件冒泡,可以控制事件的影响范围。而事件委托则是利用事件冒泡特性,在父元素上设置监听器来响应子元素的事件,这种方法减少了监听器的设置数量,特别适用于动态添加的子元素,提高了代码的可维护性和性能。掌握这两种技术,能帮助开发者构建更高效、更简洁的应用程序。
51 0
下一篇
无影云桌面