webpack从配置到跑路v4

webpack是一个打包模块化JavaScript的工具,它会从入口模块出发,识别源码中的模块化导入语句,递归查找入口文件的所有依赖,将入口和其所有的依赖打包到一个单独的文件中

默认入口:src/index.js
默认输入:dist/main.js
默认支持多种模块化类型,如commonJS、esmodule、AMD
默认支持js模块和json模块

webpack配置文件:webpack.config.js
webpack基于node,所以其配置文件遵循CommonJS规范,通过 module.exports 导出一个对象

处理JS文件中引入的 xxx.css

css-loader
style-loader

css-loader 通过CSS in JS模式,把xxx.css中的CSS内容打包到JS中
style-loader<header> 下动态创建 <style>,并把CSS插入标签内
注意:默认情况下,每引入一个xxx.css,便会生成一个<style>
配置style-loader,合并<style>

{
    loader: 'style-loader',
    options: {
        injectType: 'singletonStyleTag'
    }
}

Plugins
扩展插件,在webpack构建流程中的特定时机注入扩展逻辑,来改变构建结果,作用于整个构建过程。
通常希望把CSS导出一个独立的文件,那么就不能使用style-loader了,而是借助插件MiniCssExtractPlugin

// module
{
    test: /\.less$/,
    use: [
        MiniCssExtractPlugin.loader,
        'css-loader',
        'postcss-loader',  // 加兼容性的前缀
        'less-loader'  // 预处理less
    ]
}
// plugins
plugins: [
    new MiniCssExtractPlugin({
        filename: '[name]_[chunkhash:8].css'  // 配置导出CSS文件的名称
    })
]

sourceMap 源代码与打包代码的映射关系,通过sourceMap定位到源代码
在development模式下,默认开启。
关闭的话在 webpack.config.js 中配置

devtool: "none"

WebpackDevServer:WDS
提升开发效率的利器:每次修改代码都要重新打包,刷新浏览器,使用WebpackDevServer来改善这方面的体验。
WDS是一个运行在内存中的开发服务器(一个express),启动之后,它会检测文件是否发生改变并自动编译、刷新

npm i webpack-dev-server -D

// package.json
"scripts": {
    "server": "webpack-dev-server"
}

//webpack.config.js
devServer: {
    contentBase: "./dist",
    port: 8081,
    open: true
}

contentBase 设置服务启动后的资源地址
port 服务的端口号
open 启动服务时,自动打开浏览器
执行 npm run server 开启服务,会发现本地没有了dist目录,这是因为WDS把打包文件放于内存中,提升运行效率。

在前端项目中自己创建一个Mock服务

npm i express -D

在项目根目录下创建server.js

const express = require('express')
const app = express()
app.get('/api/info', (req, res) => {
    res.json({
        name: 'webpack',
        age: 5
    })
})
app.listen('9092')

启动:node server.js
devServer 配置跨域

devServer: {
    //...
    proxy: {
        "/api": {
            target: "http://localhost:9092"
        }
    }
}

HMR:热模块更新,webpack的自带插件
WDS每次重新编译都会自动刷新浏览器,也就造成当前状态的丢失问题
HMR 只刷新项目中的模块,不刷新浏览器,能够保留当前状态

const webpack = require('webpack')
devServer: {
    // ...
    hot: true,
    hotOnly: true  // 热更新不要刷新浏览器
}
plugins: [
    // ...
    new webpack.HotModuleReplacementPlugin()
]

HMR 默认只支持 style-loader 处理的CSS(动态创建<style>标签),不支持MiniCssExtractPlugin处理的CSS(抽离成独立的CSS文件),而且对JS模块的修改检测不友好
JS模块需要手动设置HMR监听的模块:
if(module.hot) { // 判断HMR是否存在
// 设置HMR监听的模块
module.hot.accept('./number.js', () => {
// 监听模块发生变化的回调
})
}
HMR 会对每个模块生成一个唯一ID,当某个模块的内容发生变化时,HMR会先移除这个模块,再重新编译生成,最后触发监听回调。由开发者在回调中去处理相关页面更新。
但是对于Vue、React等框架,并不需要手动监听JS模块,这是因为它们提供的相关loader 可以使HMR与各种框架和库平滑地进行交互

  • React Hot Loader 实时调整React组件
  • Vue Loader Vue组件的HMR,开箱即用
  • Elm Hot Loader 支持Elm编程语言的HMR
  • Angular HMR 不需要使用loader,直接修改主文件NgModule 即可,它可以完全控制HMR API
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,340评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,762评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,329评论 0 329
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,678评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,583评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,995评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,493评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,145评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,293评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,250评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,267评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,973评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,556评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,648评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,873评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,257评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,809评论 2 339

推荐阅读更多精彩内容