热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

wepack性能优化contenthash(缓存)

babel缓存:babel-loader在执行的时候,可能会产生一些运行期间重复的公共文件,造成代码体积大冗余,同时也会减慢编译效率(已进行了bable兼容性处理的js进行缓存,再

  1. babel 缓存:
  2.   babel-loader在执行的时候,可能会产生一些运行期间重复的公共文件,造成代码体积大冗余,同时也会减慢编译效率(已进行了 bable 兼容性处理的 js 进行缓存,再次构建的时候就不用重新 babale-loader 处理兼容问题)

      设置:cacheDirectory:true

           让第二次打包构建速度更快

  3. 文件资源 缓存
    ①hash: 每次使用webpack打包构建时会生成一个唯一的hash值
  4.         可以给打包出口的.js 和 单独打包的.css的文件名,动态添加hash值,

            这样可以达到修改源码,服务器也会改变,因为每次打包文件名都变了,服务器需要重新找

    ②问题: 但是js 和 css 同时用一个hash值

            如果重新打包, 会导致所有缓存失效.(可能就因为改一个文件,就导致整个缓存失效)
    技术分享图片
    技术分享图片

  5. 使用chunkhash值:
  6. chunkhash: 根据chunk生成的hash值. 如果打包来源同一个chunk, 那么hash值就一样,

               但是:使用chunkhash了, js 和css 的hash值还是一样的

               因为:css是在 入口js中被引入的, 所以同属于一个chunk(所以hash值还是一样的)
    技术分享图片
    技术分享图片

  7. 终武器contenthash登场:
  8. contenthash: 根据文件的内容生成hash值, 不同文件hash值一定不一样

          contenthash作用:

            通过使用contenthash,可以做到重新打包代码上线的时候,用户只需要更新有变化的代码,

            而没有变化的代码,用户可以直接使用本地缓存

          contenthash功能:

            源代码发生变化, contenthash则发生变化

            源代码不变, contenthash不变

    *让代码上线运行缓存更好使用

    技术分享图片
    css 和 js 的 hash 终于不一样了
    技术分享图片

    然后修改一下 js文件,看看hash值是否发生变化:发现只有js的hash值变了, css还是和上面的一样,这就说明了:

    源代码发生变化, contenthash则发生变化,

    因为没有修改css文件,所以css的hash不会发生变化
    技术分享图片

    css请求的是缓存中的 数据没有发送请求(所以hash没有变)

    js的文件被修改了,hash也会跟着改变, (服务器又找不到之前的js名,所以又重新发送请求了)

    技术分享图片
    wenpack.config.js *需要自己配置 一个node服务器来 测试运行

    const { resolve } = require(‘path‘);
    const htmlWebpackPlugins = require(‘html-webpack-plugin‘)// 引入html插件
    const cssWebpackPlugins = require(‘mini-css-extract-plugin‘)// 引入单独css插件
    const OptimizeCssAssetsWebpackPlugin = require(‘optimize-css-assets-webpack-plugin‘)//压缩css
    // 定义node环境变量,决定使用browserslist的哪个环境
    process.env.NODE_ENV = ‘production‘;
    // 复用loader
    const commOnCssLoader= [
    cssWebpackPlugins.loader,// 单独的css文件
    ‘css-loader‘, {
    // 还需在package.json中定义browserslist
    loader: ‘postcss-loader‘,
    options: {
    ident: ‘postcss‘,
    plugins: () => {
    require(‘postcss-preset-env‘)();
    },
    },
    },
    ]
    /*
    正常来讲,一个文件只能被一个loader处理
    当一个文件要被多个loader处理,那么一定要指定loader执行的先后顺序:
    先执行eslint再执行babel
    */
    module.exports = {
    entry: ‘./src/js/index.js‘, // 入口文件
    output: {// 出口文件
    filename: ‘js/build.[contenthash:10].js‘,// 带上打包的hash值
    path: resolve(__dirname, ‘build‘),
    },
    module: {
    rules: [
    { // 检查js语法eslint
    // 在package.josn中eslintConfig --> airbnb
    test: /\.js$/,
    exclude: /node_module/,// 排除
    // 优先执行
    enforce: ‘pre‘,
    loader: ‘eslint-loader‘,
    options: {
    fix: true // eslit自动帮你格式化js的不规范语法
    }
    },
    {
    // 以下loader只会匹配一个
    // 注意: 不能有两个配置处理同一种类型文件
    oneOf:[
    {// 打包css
    test: /\.css$/,
    use: [
    ...commonCssLoader
    ],
    },
    {// 打包scss
    test: /\.scss$/,
    use: [
    ...commonCssLoader, // 引入loader
    ‘sass-loader‘,
    ],
    },
    { // js兼容性
    // 在package.josn中eslintConfig --> airbnb
    test: /\.js$/,
    exclude: /node_module/,// 排除
    loader: ‘babel-loader‘,
    options: {
    presets: [
    [
    ‘@babel/preset-env‘,
    {
    // 按需加载
    useBuiltIns: ‘usage‘,
    // 指定core-js版本
    corejs: { version: 3 },
    targets: {
    chrome: ‘60‘,
    firefox: ‘50‘,
    ie: ‘9‘,
    edge: ‘17‘,
    safari: ‘10‘
    },
    },
    ],
    ],
    // 开始babel缓存
    // 第二次构件时, 会读取之前的缓存
    cacheDirectory:true
    }
    },
    {// 打包图片
    test: /\.(jpg|png|gif)$/,
    loader: ‘url-loader‘,
    options: {
    limit: 8 * 1024,
    name: ‘[hash:10].[ext]‘,
    outputPath: ‘imgs‘,//保存的路径
    esModule: false,//关闭es6模块化
    name:‘[hash:10].[ext]‘,// 处理后的名字长度
    }
    },
    {// 打包html插入的图片
    test: /\.html$/,
    loader: ‘html-loader‘
    },
    {// 打包其他文件, 除了上面打包过的
    exclude: /\.(js|css|less|html|jpg|png|gif)$/,
    loader: ‘file-loader‘,
    options: {
    outputPath: ‘media‘,//保存的路径
    name:‘[hash:10].[ext]‘,// 处理后的名字长度
    }
    }]
    }
    ],
    },
    plugins: [
    new cssWebpackPlugins({ // 打包成单独的css插件
    filename: ‘css/build.[contenthash:10].css‘,
    }),
    new OptimizeCssAssetsWebpackPlugin(), // 压缩css插件
    new htmlWebpackPlugins({ // html插件
    template: ‘./src/index.html‘,
    minify: {
    collapseWhitespace: true,// 清除两边空白
    removeComments: true// 清除备注
    }
    })
    ],
    mode: ‘production‘, // 环境模式,
    devtool:‘source-map‘// 报错追踪
    };


    服务器配置:server.js

    /* node server 开启服务器 */
    /* http:localhost:3000 */
    // 引入框架
    const express = require(‘express‘);
    // 使用框架
    const app = express();
    // 中间件
    app.use(express.static(‘build‘,{maxAge:1000 * 3600}))// 缓存过期时间
    // 监听端口
    app.listen(3000,function(){
    console.log(‘服务器开启成功‘);

    })


推荐阅读
  • 二维码的实现与应用
    本文介绍了二维码的基本概念、分类及其优缺点,并详细描述了如何使用Java编程语言结合第三方库(如ZXing和qrcode.jar)来实现二维码的生成与解析。 ... [详细]
  • 默认情况下,Git 使用 Nano 编辑器进行提交信息的编辑,但如果您更喜欢使用 Vim,可以通过简单的配置更改来实现这一变化。本文将指导您如何通过修改全局配置文件来设置 Vim 作为默认的 Git 提交编辑器。 ... [详细]
  • 探讨如何在映射文件中处理重复的属性字段,以避免数据操作时出现错误。 ... [详细]
  • 3DSMAX制作超现实的体育馆模型
    这篇教程是向脚本之家的朋友介绍3DSMAX制作超现实的体育馆模型方法,教程制作出来的体育馆模型非常地不错,不过教程有点难度,需要有一定基础的朋友学习,推荐到脚本之家,喜欢的朋友可 ... [详细]
  • 网络流24题——试题库问题
    题目描述:假设一个试题库中有n道试题。每道试题都标明了所属类别。同一道题可能有多个类别属性。现要从题库中抽取m道题组成试卷。并要求试卷包含指定类型的试题。试设计一个满足要求的组卷算 ... [详细]
  • 为何Compose与Swarm之后仍有Kubernetes的诞生?
    探讨在已有Compose和Swarm的情况下,Kubernetes是如何以其独特的设计理念和技术优势脱颖而出,成为容器编排领域的领航者。 ... [详细]
  • 本文探讨了程序员这一职业的本质,认为他们是专注于问题解决的专业人士。文章深入分析了他们的日常工作状态、个人品质以及面对挑战时的态度,强调了编程不仅是一项技术活动,更是个人成长和精神修炼的过程。 ... [详细]
  • 在1995年,Simon Plouffe 发现了一种特殊的求和方法来表示某些常数。两年后,Bailey 和 Borwein 在他们的论文中发表了这一发现,这种方法被命名为 Bailey-Borwein-Plouffe (BBP) 公式。该问题要求计算圆周率 π 的第 n 个十六进制数字。 ... [详细]
  • 本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ... [详细]
  • 我的读书清单(持续更新)201705311.《一千零一夜》2006(四五年级)2.《中华上下五千年》2008(初一)3.《鲁滨孙漂流记》2008(初二)4.《钢铁是怎样炼成的》20 ... [详细]
  • 本文详细介绍了C++中的构造函数,包括其定义、特点以及如何通过构造函数进行对象的初始化。此外,还探讨了转换构造函数的概念及其在不同情境下的应用,以及如何避免不必要的隐式类型转换。 ... [详细]
  • 本文详细介绍了iOS应用的生命周期,包括各个状态及其转换过程中的关键方法调用。 ... [详细]
  • 本文将从基础概念入手,详细探讨SpringMVC框架中DispatcherServlet如何通过HandlerMapping进行请求分发,以及其背后的源码实现细节。 ... [详细]
  • Windows操作系统提供了Encrypting File System (EFS)作为内置的数据加密工具,特别适用于对NTFS分区上的文件和文件夹进行加密处理。本文将详细介绍如何使用EFS加密文件夹,以及加密过程中的注意事项。 ... [详细]
  • 回顾两年前春节期间的一个个人项目,该项目原本计划参加竞赛,但最终作为练习项目完成。独自完成了从编码到UI设计的全部工作,尽管代码量不大,但仍有一定的参考价值。本文将详细介绍该项目的背景、功能及技术实现。 ... [详细]
author-avatar
纠结不停的孩子
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有