五大核心:

模式 production development
mode: 'development',

入口
entry: './src/js/index.js',

loader的配置
module: {},

plugins的配置
plugins: [],

输出
output: {},

开发环境:

loader的配置

处理css

处理less

处理图片

处理其他资源

plugins的配置

开发服务器

生产环境:

主要是对html、js、css、img压缩 以及兼容性的处理

css 、less 的兼容性处理,提取js中的css成单独文件,loader简单封装

js的语法检查以及兼容性处理

图片的压缩以及其他资源的打包

html、css的压缩 js在生产环境下会自动压缩

webpack的优化

# webpack性能优化
* 开发环境性能优化
* 生产环境性能优化

## 开发环境性能优化
* 优化打包构建速度
   * HMR

* 优化代码调试
   * source-map

## 生产环境性能优化
* 优化打包构建速度
   * oneOf
   * babel 缓存
   * 多进程
   * externals
   * dll
* 优化代码运行的性能
   * 缓存(hash-chunkhash-contenthash)
   * tree shaking 树摇 去除无用代码 前提es6
   * code split 代码分割
   * 懒加载、预加载
   * pwa

开发环境-优化

HMR

开发模式的代码调试优化   devtool: 'eval-soure-map'

生产环境-优化

oneOf 优化生产环境打包速度

babel缓存、文件资源缓存

由于资源在强制缓存期间不会访问服务器,未更新,所以给资源名称做处理 加hash值

tree shaking:树摇 为了去除无用代码,只打包使用代码

代码分割,将文件分成多个文件,按需加载,主要是js代码

1.通过多入口来拆分文件,不太灵活

2. optimization

比如 多个文件中 都引入 jquery 库

3. 通过js来让某个文件被单独打包成一个chunk

默认根据id来命名,比如0.js;  可以通过注释来修改chunk名称

/* webpackChunkName: 'test' */

js文件的 懒加载、预加载

比如:两个文件被引入,会一起加载

// 懒加载:当文件需要使用时才加
     // 预加载 prefetch:会在是用之前,提前加载js文件

PWA

渐进式网络开发应用程序(离线可访问技术)

谷歌开源插件 workbox --> workbox-webpack-plugin

需要在入口文件中注册serviceWorker / 处理兼容性问题

1. 编译会报错

2. serviceWorker代码必须运行在服务器上

注册成功

多进程

建议:js代码多的情况下使用,js少的话反而起可能起到反作用 ,勿滥用

externals 忽略打包第三方文件

dll 动态连接库

使用dll技术,对某些库(第三方库:jquery/react/vue)进行单独打包

需要单独创建文件

通过dll 将jquey打包好以后 以后可直接引用即可

webpack 0-1 配置 以及 (性能优化)的更多相关文章

  1. [记录]NGINX配置HTTPS性能优化方案一则

    NGINX配置HTTPS性能优化方案一则: 1)HSTS的合理使用 2)会话恢复的合理使用 3)Ocsp stapling的合理使用 4)TLS协议的合理配置 5)False Start的合理使用 6 ...

  2. vue-cli3项目搭建配置以及性能优化

    项目初始化 注意:安装前请确保有安装node.js,并且node>=8.9 全局安装vue npm install -g @vue/cli 如果之前安装了vue旧版本,查看vue --versi ...

  3. mysql配置以及性能优化(转)

    MySQL配置文件my.cnf中文详解,附mysql性能优化方法分享 ================================================================= ...

  4. Tomcat安全配置与性能优化

    Tomcat 是 Apache软件基金会下的一个免费.开源的WEB应用服务器,它可以运行在 Linux 和 Windows 等多个平台上,由于其性能稳定.扩展性好.免费等特点深受广大用户喜爱.目前,很 ...

  5. nginx全局配置和性能优化

    nginx目录结构和命令 1.ls /apps/nginx/:         html是测试页,sbin是主程序 2.ls /apps/nginx/sbin/:  nginx 只有一个程序文件 3. ...

  6. Tomcat 安全配置与性能优化

    一.Tomcat内存优化 1.JAVA_OPTS参数说明 Tomcat内存优化主要是对 tomcat 启动参数优化,我们可以在 tomcat 的启动脚本 catalina.sh 中设置 JAVA_OP ...

  7. Tomcat8安装, 安全配置与性能优化(转)

    一.Tomcat 安装 官网:http://tomcat.apache.org/ Tomcat8官网下载地址:http://tomcat.apache.org/download-80.cgi 为了便于 ...

  8. Tomcat8安装, 安全配置与性能优化

    一.Tomcat 安装 官网:http://tomcat.apache.org/ Tomcat8官网下载地址:http://tomcat.apache.org/download-80.cgi 为了便于 ...

  9. Nginx基本配置、性能优化指南

    大多数的Nginx安装指南告诉你如下基础知识——通过apt-get安装,修改这里或那里的几行配置,好了,你已经有了一个Web服务器了!而且,在大多数情况下,一个常规安装的nginx对你的网站来说已经能 ...

  10. 绝对详细!Nginx基本配置、性能优化指南

    大多数的Nginx安装指南告诉你如下基础知识——通过apt-get安装,修改这里或那里的几行配置,好了,你已经有了一个Web服务器了!而且,在大多数情况下,一个常规安装的nginx对你的网站来说已经能 ...

随机推荐

  1. 视频中ppt、代码、ubuntu环境请扫描下面二维码,回复:ubuntu,即可获得

    历时4个多月,第一期Linux驱动视频录制完毕, 一共32期,现在全部同步到了B站. 如果你觉得视频对你有用,建议大家多多点赞,投投免费硬币, 算是对我辛苦的劳动的认可. 视频中ppt.代码.ubun ...

  2. 代码随想录Day17

    654.最大二叉树 给定一个不重复的整数数组 nums . 最大二叉树 可以用下面的算法从 nums 递归地构建: 创建一个根节点,其值为 nums 中的最大值. 递归地在最大值 左边 的 子数组前缀 ...

  3. 离线安装python包

    1.制作requirement.txt pip freeze > requirements.txt 2.离线下载安装包 #下载单个离线包 pip download -d your_offline ...

  4. linux下开发编辑器vim常用指令

    1.vim的3种模式:编辑模式.插入模式.命令行模式(最后一行模式) 编辑模式:对代码的修改(复制.粘贴.剪切 插入模式:用户编辑代码等等) 命令行模式:保存 退出 另存为等 vim3种模式的切换 最 ...

  5. KNN算法 0基础小白也能懂(附代码)

    KNN算法 0基础小白也能懂(附代码) 原文链接 1.K近邻是啥 1968年,Cover 和 Hart 提出了最初的近邻法,思路是--未知的豆离哪种豆最近,就认为未知豆和该豆是同一种类. 近邻算法的定 ...

  6. 😶‍🌫️ SpringBoot中MongoDB的骚操作用法

    不知道大家在工作项目中有没有使用MongoDB,在哪些场景中使用.MongoDB作为NoSQL数据库,不像SQL数据库那样,可以使用Mybatis框架. 如果需要在SpringBoot中使用Mongo ...

  7. manim边学边做--角度标记

    manim中绘制一个角度其实就是绘制两条直线,本篇介绍的不是绘制角度,而是绘制角度标记. 对于锐角和钝角,角度标记是一个弧,弧的度数与角的度数一样: 对于直角,角度标记是一个垂直的拐角. manim中 ...

  8. 活动预告 | 中国数据库联盟(ACDU)中国行定档深圳,一起揭秘数据库前沿技术

    在当今数字化时代,数据库是各行各业中最核心的信息管理系统之一.随着技术的飞速发展,数据库领域也不断涌现出新的前沿技术和创新应用.数据库运维和开发人员需要紧跟前沿技术,才能保持竞争力,并实现更高效.更智 ...

  9. 创建一个简单的基于MyBatis的项目

  10. KubeSphere Namespace 数据删除事故分析与解决全记录

    作者:宇轩辞白,运维研发工程师,目前专注于云原生.Kubernetes.容器.Linux.运维自动化等领域. 前言 2023 年 7 月 23 日在项目上线前夕,K8s 生产环境出现故障,经过紧急修复 ...