一、先放上项目目录结构

二、问题总结

1、关于process.env.NODE_ENV问题

刚开始的时候,我想在配置文件中使用到这个环境变量,却发现一直获取不到值,晕晕晕,查了资料才知道,这个环境变量是给除配置文件之外的文件使用的。

因为我需要在webpack.base.conf.js配置文件中区分是开发环境还是生成环境,于是我做了如下处理:

// 第一:在我的npm脚本中加入--mode=production来确定这是生产环境
"build": "webpack --mode=production --config ./build/webpack.prod.conf.js --color --progress"
// 第二:通过process.argv判断是否存在标识--mode=production来区分开发环境和生产环境
const isProduction = process.argv.indexOf('--mode=production') > -1;

 2、关于clean-webpack-plugin插件清除文件问题

// 刚开始的时候我只是这样做了一个简单的配置,以为可以生效
// 然而,然并卵
new CleanWebpackPlugin('dist')
// 之后在阅读了插件源代码和编译提示之后,才找到问题所在(ps:源代码量不多)
// 第一:该插件只会清除插件所在文件夹下的子文件
// 第二:由于我的配置文件是在build目录下,所以插件的根目录在build文件夹
// 第三:因为我要删除的dist文件夹是build的兄弟目录,所以插件会跳过跳过跳过删除操作
// 综上所述,正确的操作是:设置项目根目录为插件的根目录
new CleanWebpackPlugin('dist', {
root: path.join(__dirname, '../')
})

3、关于extract-text-webpack-plugin提取css问题

刚开始我的配置是这样子的,忽视了我的配置是多入口的。在我打包出来之后,我的一部分css代码被提取出来的,而我配置成css module的代码却一直没有提取出来,因为这个问题,我找了一个晚上还是没有找出问题所在。

new ExtractTextPlugin("styles.css")

直到,我在webpack文档中我看到了这样的一段话:

警告: ExtractTextPlugin 对 每个入口 chunk 都生成一个对应的文件,所以当你配置多个入口 chunk 的时候,你必须使用 [name], [id] 或 [contenthash]

从这个时候我才明白,之所以存在“只提取部分代码的问题“,是因为我只设置了一个文件,导致了文件内容覆盖,后面入口文件提取出来的css覆盖了前面入口文件提取出来的css。

哭晕在厕所。。。

// 正确的操作如下:
new ExtractTextPlugin({
// 如果需要加上文件目录'css/[name].css',则需要考虑css里面应用文件相对目录问题
filename: '[name].css',
allChunks: true
})

4、关于css文件压缩问题

刚开始,我用了css-loader提供的minimize选项,不可能的,这辈子都不可能完成压缩的

{
loader: 'css-loader',
options: {
minimize: true
}
}

查了资料才发现,原来css-loader已经在新版本已经移除了minimize这个压缩选项,而推荐了其他的方案:

use postcss-loader with cssnano
use optimize-cssnano-plugin

而我采取了其中的第一种压缩方案,即postcss的方案,顺便也学习下postcss的配置,安装了postcss-loader和cssnano依赖之后,需要做如下配置:

// 第一:在需要用postcss处理的文件加入postcss-loader
test: /\.css/,
use:['style-loader','css-loader','postcss-loader']
// 第二:配置postcss,需要在项目根目录新建文件postcss.config.js
module.exports = {
plugins: [
require('cssnano')({
preset: 'default'
}),
]
};

5、有待更新...

三、总结

在学习webpack的过程中,我主要以webpack中文文档(https://webpack.docschina.org/concepts/)和github这两个网站为主,当然也少不了百度和google。学习下来发现,只要你认真看官方文档及去github上找官方给出来的示例,总能找到你的解决方案。

最后,贴出我的demo(https://github.com/xieqian-xq/demo/tree/master/webpack)。

还请各位大神多多指教

webpack4之踩坑总结的更多相关文章

  1. 升级至webpack4.x踩坑记(热更新局部更新失败的问题修复)

    零.前言 webpack升级的时候,会碰到各种个样的问题,大多数网上都能查到解决方案最简单的方案. 思路如下: 1.把css-loader,xxxloader等依赖都升级到最新 2.根据webpack ...

  2. webpack踩坑--webpack 2.x升级至4.x

    一.安装webpack-cli,webpack@4.26.1 1.npm install webpack-cli -D 2.npm install webpack@4.26.1 -D 二.踩坑 执行n ...

  3. Spark踩坑记——Spark Streaming+Kafka

    [TOC] 前言 在WeTest舆情项目中,需要对每天千万级的游戏评论信息进行词频统计,在生产者一端,我们将数据按照每天的拉取时间存入了Kafka当中,而在消费者一端,我们利用了spark strea ...

  4. Spark踩坑记——数据库(Hbase+Mysql)

    [TOC] 前言 在使用Spark Streaming的过程中对于计算产生结果的进行持久化时,我们往往需要操作数据库,去统计或者改变一些值.最近一个实时消费者处理任务,在使用spark streami ...

  5. 【踩坑速记】二次依赖?android studio编译运行各种踩坑解决方案,杜绝弯路,总有你想要的~

    这篇博客,只是把自己在开发中经常遇到的打包编译问题以及解决方案给大家稍微分享一下,不求吸睛,但求有用. 1.大家都知道我们常常会遇到dex超出方法数的问题,所以很多人都会采用android.suppo ...

  6. NPOI导出Excel (C#) 踩坑 之--The maximum column width for an individual cell is 255 charaters

    /******************************************************************* * 版权所有: * 类 名 称:ExcelHelper * 作 ...

  7. 我的微信小程序入门踩坑之旅

    前言 更好的阅读体验请:我的微信小程序入门踩坑之旅 小程序出来也有一段日子了,刚出来时也留意了一下.不过赶上生病,加上公司里也有别的事,主要是自己犯懒,就一直没做.这星期一,赶紧趁着这股热乎劲,也不是 ...

  8. router路由去掉#!的踩坑记

    项目中在研究去掉router#!的过程中的踩坑过程.

  9. vue+ vue-router + webpack 踩坑之旅

    说是踩坑之旅 其实是最近在思考一些问题 然后想实现方案的时候,就慢慢的查到这些方案   老司机可以忽略下面的内容了 1)起因  考虑到数据分离的问题  因为server是express搭的   自然少 ...

随机推荐

  1. nginx上配置phpmyadmin

    Nginx配置phpmyadmin流程如下: 一.准备软件和环境(这里我以ubuntu16.04为例) 1.安装php7.1 sudo LC_ALL=C.UTF- add-apt-repository ...

  2. React 合并行 RowSpan

    十年河东,十年河西,莫欺少年穷 学无止境,精益求精 今儿分享一篇关于React Table 组件合并单元行的方法! 实例效果如下: 原则就是遇到相同的供方名称,就要做行合并! 思路如下:后端计算合并的 ...

  3. TCP三次握手原理,你真的了解吗?

    最近碰到一个问题,Client 端连接服务器总是抛异常.在反复定位分析.并查阅各种资料搞懂后,我发现并没有文章能把这两个队列以及怎么观察他们的指标说清楚. 问题描述 场景:Java 的 Client ...

  4. 打包优化实践(如何Code Spliting)

    项目地址:ReactSPA 使用 webpack 插件找出占用空间较大的包 开发环境中可使用 analyze-webpack-plugin 观察各模块的占用情况.以该项目为例:浏览器中输入 http: ...

  5. ORA-01578 data block corrupted 数据文件损坏 与 修复 (多为借鉴 linux)

    好吧,先说说造成崩溃的原因: 使用redhat 5.9 Linux 作为数据库服务器, 周五数据库正在使用中,硬关机造成数据库文件部分损坏(周一上班时,应用程序启动不起来,查看日志文件时,发现一个数据 ...

  6. js语言规范_ES5-6-7_个人总结

    ## **理解ES** 1. 全称: ECMAScript 2. js语言的规范 3. 我们用的js是它的实现 4. js的组成   * ECMAScript(js基础)   * 扩展-->浏览 ...

  7. 【php-fpm】启动PHP报错ERROR: [pool www] cannot get uid for user 'apache'

    将@php_fpm_user@改为当前系统的用户名apache, 然后重新启动就ok了 注意:创建apache用户及用户组,上述命令换deamon为apache 

  8. Feature Pyramid Networks for Object Detection比较FPN、UNet、Conv-Deconv

    https://vitalab.github.io/deep-learning/2017/04/04/feature-pyramid-network.html Feature Pyramid Netw ...

  9. LCD学习

    LCD简介(1)显示器,常见显示器(2)LCD(Liquid Crystal Display),液晶显示器,原理介绍(3)LCD应用领域(4)LED OLED1.17.1.2.电子显示器的原理(1)像 ...

  10. SpringBoot之普通类获取Spring容器中的bean

    package com.geostar.geostack.git_branch_manager.common; import org.springframework.beans.BeansExcept ...