前端工程化之: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)); // <= 起作用

浏览器:

相关推荐
低代码布道师16 小时前
Next.js 16 全栈实战(一):从零打造“教培管家”系统——环境与脚手架搭建
开发语言·javascript·ecmascript
鹏北海-RemHusband16 小时前
从零到一:基于 micro-app 的企业级微前端模板完整实现指南
前端·微服务·架构
LYFlied16 小时前
AI大时代下前端跨端解决方案的现状与演进路径
前端·人工智能
光影少年16 小时前
AI 前端 / 高级前端
前端·人工智能·状态模式
一位搞嵌入式的 genius16 小时前
深入 JavaScript 函数式编程:从基础到实战(含面试题解析)
前端·javascript·函数式
anOnion16 小时前
构建无障碍组件之Alert Dialog Pattern
前端·html·交互设计
choke23317 小时前
[特殊字符] Python 文件与路径操作
java·前端·javascript
云飞云共享云桌面17 小时前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
Deng94520131417 小时前
Vue + Flask 前后端分离项目实战:从零搭建一个完整博客系统
前端·vue.js·flask
威迪斯特17 小时前
Flask:轻量级Web框架的技术本质与工程实践
前端·数据库·后端·python·flask·开发框架·核心架构