[Node] Node.js Webpack常见的模式

简介: [Node] Node.js Webpack常见的模式

一、认识插件 Plugin

认识Plugin

Webpack的另一个核心是Plugin 官方有这样一段话对Plugin的描述


While loaders are used to transform certain types of modules, plugins can be leveraged to perform a wider range of tasks like bundle optimization,asset management and injection of environment variables


翻译过来就是:


loader是用来 特性的模块类型 进行转换


Plugin是可以用于 执行更加广泛的任务 如 打包优化 资源管理 环境变量注入等

c4efef8861964cfe83bb32a2045976f3.png

二、CleanWebpackPlugin

我们每次修改一些配置 重新打包时 都需要手动删除 dist文件夹


可以借助这个插件来帮助我们完成


首先 安装这个插件

JavaScript

npm install clean-webpack-plugin -D


之后在插件中配置

JavaScript
const  {CleanWebpackPlugin} = require('clean-webpack-plugin')
module.exports = {
    // 其他省略 ...
    plugins:[
        new CleanWebpackPlugin()
    ]
}

三、HtmlWebpackPlugin

另外还有一个不太规范的地方:


我们的HTML文件是编写在根目录的,最终打包的dist文件夹中没有index.html文件的


在进行项目部署时 必须也是需要有对应的入口文件index.html


所以我们也需要对index.html进行打包管理


对HTML进行打饱处理 可以使用另一个插件 HtmlWebpackPlugin

JavaScript
npm install html-webpack-plugin -D
JavaScript
const HtmlWebpackPlugin = require('html-webpack-plugin')
module.exports = {
    // 其他省略 ...
    plugins:[
        new HtmlWebpackPlugin({
            title:"电商项目"
        })
    ]
}

生成index.html分析

自动在dist文件中 生成了一个index.html文件


该文件中也自动添加了我们打包的js文件


这个文件是如何生成的?


默认情况下根据ejs的一个模块来生成的


在html-webpack-plugin的源码中,有一个defaults_index.ejs模块

自定义HTML模版

如果我们想在自己的模块中加入一些比较特别的内容:


如添加一个 noscript标签 在用户的JS被关闭时 给予响应的提示


如在开发vue或react项目时 需要一个可以挂在后续组件的跟标签

自定义模版数据填充

在配置HtmlWebpackPlugin时 我们可以添加如下配置


Temolate: 指定我们曜使用的模块所在的路径


title:在进行HtmlWebpackPlugin.options.title读取时 就会读到该信息

四、DefinePlugin

DefinePlugin的介绍

这个时候编译还会报错 因为我们的模块中还是用到一个 BASE_URL的常量:

5392d946e4974486be5e060e9a5d973a.png

这是因为在编译 template模块时 有一个 BASE_URL:

<link rel="icon" href="<%=BASE_URL %">favicon.ico">

但是我们并没有设置过这歌常量值,所以会出现没有定义的错误


这个时候我们可以使用DefinePlugin插件;


DefinePlugin的使用


DefinePlugin允许在编译时创建配置的全局常量 是一个webpack内置的插件(不需要单独安装):

JavaScript
const {DefinePlugin} = require('webpack')
module.exports = {
    // 其他省略
    plugins:[
        new DefinePlugin({
            BASE_URL:'"./"'
        })
    ]
}

五、Mode模式配置

Mode配置

Mode配置选项 可以告知webpack使用相应模式的内置优化


默认值是production(什么都不设置的情况下)


可选值有:

'none'|'development'|'production'

4dcf8e787939415caccab8e457040fa0.png

相关文章
|
2月前
|
缓存 JavaScript 前端开发
js开发:请解释什么是Webpack,以及它在项目中的作用。
Webpack是开源的JavaScript模块打包器,用于前端项目构建,整合并优化JavaScript、CSS、图片等资源。它实现模块打包、代码分割以提升加载速度,同时进行资源优化和缓存。借助插件机制扩展功能,并支持热更新,加速开发流程。
20 4
|
3月前
|
JSON JavaScript 前端开发
JS服务端技术—Node.js知识点
本篇文章是我开始系统学习Node.js的一些笔记。如果文中阐述不全或不对的,多多交流。
62 0
JS服务端技术—Node.js知识点
|
4月前
|
JavaScript
node下的two.js调用one.js出现无法编译问题 Cannot find module ‘c:
node下的two.js调用one.js出现无法编译问题 Cannot find module ‘c:
48 0
|
4月前
|
JavaScript 前端开发 API
释放 Node.js 的力量:服务器端 JavaScript 综合指南
释放 Node.js 的力量:服务器端 JavaScript 综合指南
31 0
|
4月前
|
JavaScript
Turndown 源码分析:五、节点相关`root-node.js`和`node.js`
Turndown 源码分析:五、节点相关`root-node.js`和`node.js`
29 0
|
3月前
|
消息中间件 Web App开发 JavaScript
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)
77 0
|
3天前
|
存储 JavaScript 前端开发
❤Nodejs 第十四章(node中间件multer的认识安装使用)
【4月更文挑战第14天】Multer是Node.js用于处理multipart/form-data的中间件,专注于文件上传。。基本用法包括设置存储引擎,如磁盘存储(DiskStorage)或内存存储(MemoryStorage),并指定处理单个或多个文件的方法。例如,`multer.single(&#39;file&#39;)`处理单个文件上传。存储引擎DiskStorage适合永久保存,而MemoryStorage适合临时处理。可以通过`limits`选项限制文件大小,实现不同类型的文件有不同的大小限制。
12 0
|
22天前
报错/ ./node_modules/axios/lib/platform/index.js Module parse failed: Unexpected token (5:2)怎么解决?
报错/ ./node_modules/axios/lib/platform/index.js Module parse failed: Unexpected token (5:2)怎么解决?
|
3月前
|
存储 前端开发 JavaScript
Webpack【Webpack中模式(Mode)、Webpack中使用DevServer、Webpack中devtool增强调试过程】(二)-全面详解(学习总结---从入门到深化)
Webpack【Webpack中模式(Mode)、Webpack中使用DevServer、Webpack中devtool增强调试过程】(二)-全面详解(学习总结---从入门到深化)
50 0
|
6天前
|
缓存 JavaScript 前端开发
js开发:请解释什么是Webpack,以及它在项目中的作用。
Webpack是开源的JavaScript模块打包器,用于前端项目构建,整合并优化JavaScript、CSS、图片等资源。它实现模块打包、代码分割以提升加载速度,同时进行资源优化和缓存。Webpack的插件机制可扩展功能,支持热更新以加速开发流程。
13 2