[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

相关文章
|
7天前
|
JavaScript 前端开发 安全
【逆向】Python 调用 JS 代码实战:使用 pyexecjs 与 Node.js 无缝衔接
本文介绍了如何使用 Python 的轻量级库 `pyexecjs` 调用 JavaScript 代码,并结合 Node.js 实现完整的执行流程。内容涵盖环境搭建、基本使用、常见问题解决方案及爬虫逆向分析中的实战技巧,帮助开发者在 Python 中高效处理 JS 逻辑。
|
10月前
|
Web App开发 JavaScript 前端开发
Node.js 是一种基于 Chrome V8 引擎的后端开发技术,以其高效、灵活著称。本文将介绍 Node.js 的基础概念
Node.js 是一种基于 Chrome V8 引擎的后端开发技术,以其高效、灵活著称。本文将介绍 Node.js 的基础概念,包括事件驱动、单线程模型和模块系统;探讨其安装配置、核心模块使用、实战应用如搭建 Web 服务器、文件操作及实时通信;分析项目结构与开发流程,讨论其优势与挑战,并通过案例展示 Node.js 在实际项目中的应用,旨在帮助开发者更好地掌握这一强大工具。
276 1
|
9月前
|
存储 JavaScript NoSQL
Node.js新作《循序渐进Node.js企业级开发实践》简介
《循序渐进Node.js企业级开发实践》由清华大学出版社出版,基于Node.js 22.3.0编写,包含26个实战案例和43个上机练习,旨在帮助读者从基础到进阶全面掌握Node.js技术,适用于初学者、进阶开发者及全栈工程师。
147 9
|
10月前
|
JSON JavaScript 前端开发
使用JavaScript和Node.js构建简单的RESTful API
使用JavaScript和Node.js构建简单的RESTful API
|
10月前
|
开发框架 JavaScript 前端开发
Node.js日记:客户端和服务端介绍、Node.js介绍
Node.js日记:客户端和服务端介绍、Node.js介绍
|
10月前
|
JavaScript 前端开发 开发工具
Node.js——初识Node.js
Node.js——初识Node.js
140 4
|
10月前
|
JavaScript 前端开发 持续交付
构建现代Web应用:Vue.js与Node.js的完美结合
【10月更文挑战第22天】随着互联网技术的快速发展,Web应用已经成为了人们日常生活和工作的重要组成部分。前端技术和后端技术的不断创新,为Web应用的构建提供了更多可能。在本篇文章中,我们将探讨Vue.js和Node.js这两大热门技术如何完美结合,构建现代Web应用。
307 4
|
设计模式 JavaScript 前端开发
模式(一)javascript设计模式
模式(一)javascript设计模式
|
JavaScript 前端开发 设计模式
模式(一)javascript设计模式
模式有三种:Architectural Pattern、Design Pattern、Coding Pattern,即:框架模式、设计模式、编程模式。本文主要讲解javascript中的设计模式,好的设计模式能够提高代码的重用性,可读性,使代码更容易的维护和扩展。
807 0