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

浏览器:

相关推荐
小白学大数据6 分钟前
JavaScript重定向对网络爬虫的影响及处理
开发语言·javascript·数据库·爬虫
qq_3901617714 分钟前
防抖函数--应用场景及示例
前端·javascript
3345543242 分钟前
element动态表头合并表格
开发语言·javascript·ecmascript
John.liu_Test44 分钟前
js下载excel示例demo
前端·javascript·excel
Yaml41 小时前
智能化健身房管理:Spring Boot与Vue的创新解决方案
前端·spring boot·后端·mysql·vue·健身房管理
PleaSure乐事1 小时前
【React.js】AntDesignPro左侧菜单栏栏目名称不显示的解决方案
前端·javascript·react.js·前端框架·webstorm·antdesignpro
哟哟耶耶1 小时前
js-将JavaScript对象或值转换为JSON字符串 JSON.stringify(this.SelectDataListCourse)
前端·javascript·json
getaxiosluo1 小时前
react jsx基本语法,脚手架,父子传参,refs等详解
前端·vue.js·react.js·前端框架·hook·jsx
理想不理想v1 小时前
vue种ref跟reactive的区别?
前端·javascript·vue.js·webpack·前端框架·node.js·ecmascript
知孤云出岫1 小时前
web 渗透学习指南——初学者防入狱篇
前端·网络安全·渗透·web