webpack的配置

安装

npm i webpack webpack-cli

(webpack在4.x以上需要安装webpack-cli)

webpack使用时需要一个入口文件,在src下创建main.js作为入口文件,而且在main.js中可以使用任何模块化语法,什么AMD、CMD、node等等都可以使用。

当然浏览器是不认识这些模块化语法的,所以需要使用webpack对main.js这个文件进行打包。在打包的过程中,如果发现main.js中有引入其他的模块,那么会顺带将这些被依赖的模块也打包进来。

那么如何进行打包呢
在package.json中配置script标签
(script的作用是配置命令的别名)

"script":{
  //build 命令的别名
  //webpack  命令
  //./src/main.js  打包的文件
  //-o(output)  输入命令
  //./dist/bundle.js  输出文件
  "build": "webpack ./src/main.js -o ./dist/bundle.js" 
}

然后在控制台运行

npm run build

会在dist文件夹下生成bundle.js文件,所依赖的所有模块都打包进了这个文件中,所以在使用的时候直接引入这个文件就可以了,再也不用使用一堆一堆的引入语句了。

在控制台执行build命令进行打包时,会弹出一个warning

WARNING in configuration
The 'mode' option has not been set, webpack will fallback to 'production' for this value. Set 'mode' option to 'development' or 'production' to enable defaults for each environment.
You can also set it to 'none' to disable any default behavior. Learn more: https://webpack.js.org/configuration/mode/

提示没有设置mode选项,默认会设置为production,mode=production的时候,打包出来的代码是压缩过的。
想要设置的话,可以把打包命令加上mode

"script":{
  "build":"webpack ./src/main.js -o ./dist/bundle.js --mode development"
}

到这里引入一个新问题,如果所有命令都配置到一行,那么也太长了,所以这里要开始使用webpack的配置文件了。

在项目根目录下新建一个叫做webpack.config.js的文件,这就是webpack的配置文件。
现在我们修改script标签内容如下:

"script":{
  "build":"webpack"
}

现在执行npm run build的时候,webpack会自动查询webpack.config.js文件,这个配置文件运行在node环境下(webpack都是运行在node环境下),所以这个文件的书写方式是nodejs语法。

const path = require('path')

module.exports = {
    //入口文件
    entry: path.join(__dirname, "src", "main.js"),
    //出口文件
    output:{
        path:path.join(__dirname, 'dist'),
        filename:'bundle.js'
    },
    mode:'development'
}

webpack可以打包js,不过却不认识其他类型文件,比如css,这时候我们需要做一些额外的工作来让webpack也可以打包这些资源。

loader

loader让webpack能够处理非js文件。loader可以将所有类型文件转换为webpack能够处理的有效模块,之后我们就可以使用webpack对他们进行打包处理了。

加载CSS

加载CSS需要在module配置中安装并添加style-loadercss-loadercss-loader解释@importurl(),会import/require()后再解析他们。
安装

npm install style-loader css-loader -D

配置

//处理js以外的模块
    module: {
        rules:[
            //rules中配置规则
            {
                //测试
                test: /\.css$/,
                //loader是从右向左加载的
                //css-loader    根据模块化语法找到css文件并进行解析
                //style-loader  把css-loader生成样式,通过style标签添加到页面中
                use:['style-loader', 'css-loader']
            }
        ]
    }
加载less

安装

npm install -D less-loader less

配置

{
  test:/.\less$/,
  use:[
    {"loader":"style-loader"},
    {"loader":"css-loader"},
    {"loader":"less-loader"}
  ]
}
加载图片

安装file-loaderurl-loader
file-loader会把图片处理成另一个文件
url-loader会把图片使用base64编码存放在出口文件中,所以只适合小图片

 {
  test:/\.(jpg|gif|jpeg|png)$/,
  use:[
    {
      loader:"url-loader",
      //url-loader的加载规则
      options:{
        //打包成base64编码的图片的大小
        //如果图片小于8k,就使用url-loader来打包
        limit: 2 * 1024
      }
    }
  ]
}

如上配置及就可以了,如果图片大小超过了limit设置的值,会去使用file-loader加载。

使用babel处理ES6语法

安装

npm install --save-dev babel-loader @babel/core
module: {
  rules: [
    { test: /\.js$/, exclude: /node_modules/, loader: "babel-loader" }
  ]
}

只这样配置还不够,需要在项目根目录创建叫做.babelrc的文件
安装

npm install @babel/preset-env --save-dev

配置

{
  "presets": ["@babel/preset-env"]
}

如果配置不成功可以参考一下官网:https://www.babeljs.cn/docs/usage

插件

当使用webpack生成出口文件后(这里的是bundle.js),需要使用html去引用这个JS文件。

HtmlWebpackPlugin

这个插件简化了HTML文件的创建,以便为webpack打包提供服务。在每次webpack打包后生成一个html,并且把bundle.js引入进来。

[https://www.webpackjs.com/plugins/html-webpack-plugin/](https://www.webpackjs.com/plugins/html-webpack-plugin/)

webpack-dev-server

现在我们发现在每次文件内容更改后都要重新打包,非常麻烦,使用webpack-dev-server可以解决这个问题。
webpack-dev-server是webpack的一个辅助包,作用:
1.自动开启http服务
2.自动打开浏览器
3.自动监视文件变化
4.引入,每次修改代码,都重新打包

安装

npm i -D webpack-dev-server

配置

"script":{
  //把build属性的webpack改成webpack-dev-server
  //"build":"webpack"
  "build":"webpack-dev-server"
}

这里注意webpack-dev-server打包是打包在内存中的,在内存中读写文件性能比较高,但在实际开发时最终要打包成文件还是需要webpack的。

这里只是整理一下学习的思路,具体配置:
[https://webpack.js.org/configuration/dev-server/](https://webpack.js.org/configuration/dev-server/)
配置端口默认打开浏览器什么的都有...

配置上当项目大了每次改一点内容就全部打包也会很慢,这里最好把热更新打开,这样再打包的时候只会更新修改的代码部分。
然而使用热更新还需要加一个插件...

const webpack = require('webpack')
plugins:[
  ...,
  new webpack.HotModuleReplacementPlugin()
]

整体配置

const path = require('path')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const webpack = require('webpack')
module.exports = {
    //入口文件
    entry: path.join(__dirname, "src", "main.js"),
    //出口文件
    output:{
        path:path.join(__dirname, 'dist'),
        filename:'bundle.js'
    },
    mode:'development',
    //处理js以外的模块
    module: {
        rules:[
            //rules中配置规则
            {
                //测试
                test: /\.css$/,
                //loader是从右向左加载的
                //css-loader    根据模块化语法找到css文件并进行解析
                //style-loader  把css-loader生成样式,通过style标签添加到页面中
                use:['style-loader', 'css-loader']
            },
            {
                test:/.\less$/,
                use:[
                    {"loader":"style-loader"},
                    {"loader":"css-loader"},
                    {"loader":"less-loader"}
                ]
            },
            {
                test:/\.(jpg|gif|jpeg|png)$/,
                use:[
                    {
                        loader:"url-loader",
                        //url-loader的加载规则
                        options:{
                            //打包成base64编码的图片的大小
                            //如果图片小于8k,就使用url-loader来打包
                            limit: 2 * 1024
                        }
                    }
                ]
            },
            //使用babel处理高版本的es语法
            {
                //匹配所有js文件,把所有高版本语法转为低版本的
                test: /\.js$/, exclude: /node_modules/, loader: "babel-loader"
            }
        ]
    },
    plugins: [new HtmlWebpackPlugin({
        template:path.join(__dirname, 'src', 'index.html')   
    }, 
    new webpack.HotModuleReplacementPlugin()
    )],
    //webpack-dev-server
    devServer:{
        open:true,
        hot:true
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,133评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,682评论 3 390
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,784评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,508评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,603评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,607评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,604评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,359评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,805评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,121评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,280评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,959评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,588评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,206评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,193评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,144评论 2 352