webpack插件的使用

webpack 插件的作用

通过安装和配置第三方的插件,可以拓展 webpack 的能力,从而让 webpack 用起来更方便。最常用的 webpack 插件有如下两个:

        ① webpack-dev-server

                ⚫ 类似于 node.js 阶段用到的 nodemon 工具

                ⚫ 每当修改了源代码,webpack 会自动进行项目的打包和构建

        ② html-webpack-plugin

                ⚫ webpack 中的 HTML 插件(类似于一个模板引擎插件)

                ⚫ 可以通过此插件自定制 index.html 页面的内容

安装 webpack-dev-server

webpack-dev-server 可以让 webpack 监听项目源代码的变化,从而进行自动打包构建。

运行如下的命令,即可在项目中安装此插件:

npm install webpack-dev-server@3.11.2 -D

配置 webpack-dev-server

修改 package.json -> scripts 中的 dev 命令如下:

  "scripts": {
    "dev": "webpack serve"  // scrpit节点下的脚本,可以通过npm run 执行
  }

再次运行 npm run dev 命令,重新进行项目的打包

在浏览器中访问 http://localhost:8080 地址,查看自动打包效果

注意:webpack-dev-server 会启动一个实时打包的 http 服务器

打包生成的文件哪儿去了?

① 不配置 webpack-dev-server 的情况下,webpack 打包生成的文件,会存放到实际的物理磁盘上         ⚫ 严格遵守开发者在 webpack.config.js 中指定配置

        ⚫ 根据 output 节点指定路径进行存放

② 配置了 webpack-dev-server 之后,打包生成的文件存放到了内存中

        ⚫ 不再根据 output 节点指定的路径,存放到实际的物理磁盘上

        ⚫ 提高了实时打包输出的性能,因为内存比物理磁盘速度快很多

生成到内存中的文件该如何访问?

webpack-dev-server 生成到内存中的文件,默认放到了项目的根目录中,而且是虚拟的、不可见的。

可以直接用 / 表示项目根目录,后面跟上要访问的文件名称,即可访问内存中的文件

例如 /mian.js 就表示要访问 webpack-dev-server 生成到内存中的 mian.js 文件

所以我们知道了打包规则之后,我们就只需要将html下面的js脚本替换为内存中的即可

打开给我开启的服务器地址,我们就能访问到我们的根目录

 打开给我们的服务器地址,我们可以看到我们的根目录

 进入src目录 ,我们可以看到我们的页面了,页面功能也没有报错

到此为止,我们webpack-dev-server的插件就配置完成了

当我们在使用这个插件的时候,是不是会觉得每次打开的都是根目录 需要点击src目录进入页面显得相对麻烦吗?如何解决呢,这个时候我们就介绍一下,我们要学习的下一个插件。

安装 html-webpack-plugin (webpack热更新)

html-webpack-plugin 是 webpack 中的 HTML 插件,可以通过此插件自定制 index.html 页面的内容。 需求:通过 html-webpack-plugin 插件,将 src 目录下的 index.html 首页,复制到项目根目录中一份!

运行如下的命令,即可在项目中安装此插件:

npm install html-webpack-plugin@5.3.2 -D

配置 html-webpack-plugin

// 导入一个HTML插件 得到一个构造函数
const HtmlPlugin = require('html-webpack-plugin')
// 创建一个HtmlPlugin的实例对象
const htmlPlugin = new HtmlPlugin({
    template: './src/index.html',  // 指定源文件的存放路径
    filename: './index.html'  // 指定生成文件的存放路径
})

module.exports = {
    mode: "development",
    plugins: [htmlPlugin] // 通过配置plugins节点,使htmlPlugin插件生效
   
}

① 通过 HTML 插件复制到项目根目录中的 index.html 页面,也被放到了内存中

② HTML 插件在生成的 index.html 页面,自动注入了打包的 bundle.js 文件

我们配置完成之后,在启动服务器,进入之后就可以直接进入网页啦

注意: html-webpack-plugin 插件,会自动帮我们注入script 标签,如果我们自己再引用一遍,那就会加载两遍了。

devServer 节点

在 webpack.config.js 配置文件中,可以通过 devServer 节点对 webpack-dev-server 插件进行更多的配置, 示例代码如下:

// 使用Node.js的导出语法,向外导出一个webpack配置对象
module.exports = {
    // 代表webpack的开发模式,有两个值development和production。development代表开发模式;development代表生产模式,能够对代码进行压缩
    mode: "development",
    // entry 要处理的哪个文件
    entry:  path.join(__dirname, './src/index.js'),
    
    // 指定生成的文件要存放在哪里
    output: {
        // 存放的目录
        path: path.join(__dirname, 'dist'),
        // 生成的文件名
        filename: 'main.js'
    },
    plugins: [htmlPlugin], // 通过配置plugins节点,使htmlPlugin插件生效

    // 以通过 devServer 节点对 webpack-dev-server 插件进行更多的配置
    devServer: {
        open: true,  // 初次打包完成后自动打开浏览器
        host: 'localhost',  // 实时打包所用的打包地址
        port: 80  // 实时打包所用的端口号
    }
   
}

注意:凡是修改了 webpack.config.js 配置文件,或修改了 package.json 配置文件,必须重启实时打包的服 务器,否则最新的配置文件无法生效!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李公子丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值