前端工程化之:webpack1-13(内置插件)

目录

一、内置插件

1.DefinePlugin

2.BannerPlugin

3.ProvidePlugin


一、内置插件

所有的 webpack 内置插件都作为 webpack 的静态属性存在的,使用下面的方式即可创建一个插件对象:

javascript 复制代码
const webpack = require("webpack")

new webpack.插件名(options)

1.DefinePlugin

全局常量定义插件,使用该插件通常定义一些常量值,例如:

webpack.config.js :

javascript 复制代码
// 引入webpack内置插件
const webpack = require("webpack");

// plugins中配置
plugins: [
    new webpack.DefinePlugin({
    PI: `Math.PI`, // const PI = Math.PI
    VERSION: `"1.0.0"`, // VERSION = "1.0.0"
    DOMAIN: JSON.stringify("http://localhost:8080/html"), // DOMAIN = "duyi.com"
  }),
],

src/index.js :

javascript 复制代码
console.log(PI);
console.log(VERSION);
console.log(DOMAIN);

浏览器:

这样一来,在源码中,我们可以直接使用插件中提供的常量,当 webpack 编译完成后,会自动替换为常量的值。

2.BannerPlugin

它可以为每个 chunk 生成的文件头部添加一行注释,一般用于添加作者、公司、版权等信息。

webpack.config.js :

javascript 复制代码
new webpack.BannerPlugin({
  banner: `
  hash:[hash]
  chunkhash:[chunkhash]
  name:[name]
  author:zuozhe
  corporation:gongsi
  `
})

运行 npx webpack 打包命令后的 main.js 文件最上方会出现以下代码:

javascript 复制代码
/*!
 * 
 *       hash:07133a8cf05d494f4cba
 *       chunkhash:aeea2163831469d1baf2
 *       name:main
 *       author:zuozhe
 *       corporation:gongsi
 *       
 */

3.ProvidePlugin

自动加载模块,而不必到处 import 或 require 。

webpack.config.js :

javascript 复制代码
new webpack.ProvidePlugin({
  $: 'jquery',
  _: 'lodash'
})

src/index.js :

javascript 复制代码
console.log($("#item")); // <= 起作用
console.log(_.drop([1, 2, 3], 2)); // <= 起作用

浏览器:

相关推荐
threelab1 分钟前
Three.js 咖啡杯烟雾效果 | 三维可视化 / AI 提示词
开发语言·javascript·人工智能
Jul1en_20 分钟前
Claude 迁移 Codex 工作流迁移与更新
java·服务器·前端·后端·ai编程
Heo22 分钟前
14_React 中的更新队列 updateQueue
前端·javascript·面试
前端 贾公子29 分钟前
解决浏览器端 globalThis is not defined 报错
前端·javascript·vue.js
宁雨桥31 分钟前
前端与AI结合实战分享
前端·人工智能
之歆1 小时前
DAY12_CSS3选择器全攻略 + 盒子新特性完全指南(下)
前端·javascript·css3
kyriewen111 小时前
代码写成一锅粥?3个设计模式让你的项目“起死回生”
开发语言·前端·javascript·设计模式·ecmascript
donecoding1 小时前
pnpm 全局包与 nvm 的真相:命令永在,运行时随缘
node.js·claude
光影少年1 小时前
react函数组件、类组件、纯组件、受控/非受控组件
前端·react.js·掘金·金石计划
程序员包打听1 小时前
MoonBit 是什么?给第一次听说这门语言的你
前端·后端