webpack4.x 入门

前言:

webpack4出了以后,一些插件变化很大,和之前的版本使用方式不一样,新手入坑,本篇将介绍如何从一开始配置webpack4的开发版本,对css,js进行编译打包合并生成md5,CSS中的图片处理,js自动注入html页,删除指定文件,提取公共文件****,热更新等等。

安装

//全局安装 npm install -g webpack webpack-cli

创建文件夹初始化

//创建文件夹mkdir webpack4demo//进入cd webpack4demo//初始化npm init -y

创建文件夹scripts 里面创建index.js文件

index.js

const s=()=>{ console.log('s init')}s()

创建webpack.config.js文件

webpack.config.js

const path = require("path");module.exports = {    entry: {        index: "./scripts/index.js" //入口文件,若不配置webpack4将自动查找src目录下的index.js文件    },    output: {        filename: "[name].bundle.js",//输出文件名,[name]表示入口文件js名        path: path.join(__dirname, "dist")//输出文件路径    }}

执行webpack --mode development将会生成dist/index.bundle.js

1.png

创建index.html,并引入js

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>$Title$</title></head><body>$END$</body><script src="./dist/index.bundle.js"></script></html>

打开浏览器将会看到之前设置的js文件生效

对css,js进行编译打包合并生成md5

创建a.js,c.js,a.css,更改index.js

a.js

import acss from './a.css'import c from './c.js'const a={    init(){        console.log("a init bbbaaa")    },    cinit(){       c.init()    }}export default a;

c.js

const c={    init(){        console.log("ccccc")    }}export default c;

a.css

body{     background-color: #6b0392;}

index.js

import a from './a.js'import c from './c.js'const s=()=>{    a.init()    a.cinit()    c.init()    console.log('s init')}s()

配置webpack.config.js文件

const path = require("path");module.exports = {    entry: {        index: "./scripts/index.js"    },    output: {        filename: "[name].bundle.[hash].js",//[hash]会在后面生成随机hash值        path: path.join(__dirname, "dist")    },    module: { // 处理对应模块        rules: [            {                test: /\.css$/,                use: [ 'style-loader', 'css-loader' ]//处理css            }        ]    },}

安装style-loader, css-loader

npm install style-loader css-loader --save-dev

执行webpack --mode development将会看到一个带md5值得js文件,将他引入html中

2.png

CSS中的图片处理

安装url-loader, file-loader

npm install url-loader file-loader --save-dev

修改a.css 将一张图片放到scripts目录

body{    background-image: url("./timg.jpg");    background-color: #a748ca;}

配置webpack.config.js文件

module: {    rules: [        {            test: /\.css$/,            use: [ 'style-loader', 'css-loader' ]        },        {            test:/\.(png|jpg|gif)$/,            use:[{                loader:'url-loader',                options:{                    outputPath:'images/',//输出到images文件夹                    limit:500  //是把小于500B的文件打成Base64的格式,写入JS                }            }]        }    ]},

执行webpack --mode development将会看到dist中有一个images文件夹中有一张图片,打开index.html

3.png

js自动注入html文件

使用插件html-webpack-plugin,可以将生成的js自动引入html页面,不用手动添加

//安装html-webpack-pluginnpm install html-webpack-plugin --save-dev//安装webpack webpack-clinpm install webpack webpack-cli --save-dev

配置webpack.config.js文件

const path = require("path");const HtmlWebpackPlugin = require('html-webpack-plugin');//引入html-webpack-pluginmodule.exports = {    entry: {        index: "./scripts/index.js"    },    output: {        filename: "[name].bundle.[hash].js",        path: path.join(__dirname, "dist")    },    module: {        rules: [            {                test: /\.css$/,                use: [ 'style-loader', 'css-loader' ]            }        ]    },    plugins: [// 对应的插件        new HtmlWebpackPlugin({ //配置            filename: 'index.html',//输出文件名            template: './index.html',//以当前目录下的index.html文件为模板生成dist/index.html文件        }),    ]}

执行webpack --mode development 记得要讲之前手动引入的script删除,便可以看到dist那里自动生成一个index.html,打开便可以看到。

删除指定文件

使用插件clean-webpack-plugin,删除指定文件,更多配置,查看clean-webpack-plugin

npm install clean-webpack-plugin --save-dev

配置webpack.config.js文件

const CleanWebpackPlugin = require('clean-webpack-plugin');//引入    plugins: [// 对应的插件        new HtmlWebpackPlugin({ //配置            filename: 'index.html',//输出文件名            template: './index.html',//以当前目录下的index.html文件为模板生成dist/index.html文件        }),        new CleanWebpackPlugin(['dist']), //传入数组,指定要删除的目录    ]

执行webpack --mode development,可以看到dist目录被删除,又生成一个新的dist,之前的js文件已经被删除。

提取公共文件

我们可看到a.js和index.js都引入了c.js文件,为什么要提取公共代码,简单来说,就是减少代码冗余,提高加载速度。和之前的webpack配置不一样:

//之前配置// new webpack.optimize.SplitChunksPlugin({//     name: 'common', // 如果还要提取公共代码,在新建一个实例//     minChunks: 2, //重复两次之后就提取出来//     chunks: ['index', 'a'] // 指定提取范围// }),//现在配置optimization: {    splitChunks: {        cacheGroups: {            commons: {  // 抽离自己写的公共代码                chunks: "initial",                name: "common", // 打包后的文件名,任意命名                minChunks: 2,//最小引用2次                minSize: 0 // 只要超出0字节就生成一个新包            },            vendor: {   // 抽离第三方插件                test: /node_modules/,   // 指定是node_modules下的第三方包                chunks: 'initial',                name: 'vendor',  // 打包后的文件名,任意命名                // 设置优先级,防止和自定义的公共代码提取时被覆盖,不进行打包                priority: 10            },        }    }},

下载jqnpm install jquery --save 在a.js,index.js引用 import $ from 'jquery' 输出$

生成3个js文件,执行webpack --mode development

4.png
5.png

热更新,自动刷新

我们将用到webpack-dev-servewebpack-dev-server就是一个基于Node.jswebpack的一个小型服务器,它有强大的自动刷新热替换功能。

安装webpack-dev-serve

npm install webpack-dev-serve --save-dev

配置webpack.config.js文件

const webpack = require("webpack");plugins: [    new HtmlWebpackPlugin({        filename: 'index.html',        template: './index.html',    }),    new CleanWebpackPlugin(['dist']), //传入数组,指定要删除的目录    // 热更新,热更新不是刷新    new webpack.HotModuleReplacementPlugin()],devServer: {//配置此静态文件服务器,可以用来预览打包后项目    inline:true,//打包后加入一个websocket客户端    hot:true,//热加载    contentBase: path.resolve(__dirname, 'dist'),//开发服务运行时的文件根目录    host: 'localhost',//主机地址    port: 9090,//端口号    compress: true//开发服务器是否启动gzip等压缩},

配置package.json

"scripts": {  "dev": "webpack-dev-server --mode development"},

执行npm run dev访问 http://localhost:9090/

6.png
7.png

随便修改任一文件便会自动刷新网站显示修改相应内容。

总结:

webpack4还有很多很多配置,例如css的拆分呀,less sass配置呀,js编译es6呀,多入口配置呀,生产环境配置,js没有使用的模块自动检测剥离等等,只能等下次有空在总结,感谢大家的观看,新手入坑,欢迎指出错误的地方。

作者:eternalless
链接:https://juejin.im/post/5b2b9a00e51d45587b48075e
来源:掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

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

推荐阅读更多精彩内容