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

浏览器:

相关推荐
蟾宫曲1 小时前
在 Vue3 项目中实现计时器组件的使用(Vite+Vue3+Node+npm+Element-plus,附测试代码)
前端·npm·vue3·vite·element-plus·计时器
秋雨凉人心1 小时前
简单发布一个npm包
前端·javascript·webpack·npm·node.js
liuxin334455661 小时前
学籍管理系统:实现教育管理现代化
java·开发语言·前端·数据库·安全
qq13267029401 小时前
运行Zr.Admin项目(前端)
前端·vue2·zradmin前端·zradmin vue·运行zradmin·vue2版本zradmin
魏时烟3 小时前
css文字折行以及双端对齐实现方式
前端·css
哥谭居民00013 小时前
将一个组件的propName属性与父组件中的variable变量进行双向绑定的vue3(组件传值)
javascript·vue.js·typescript·npm·node.js·css3
踢足球的,程序猿4 小时前
Android native+html5的混合开发
javascript
2401_882726484 小时前
低代码配置式组态软件-BY组态
前端·物联网·低代码·前端框架·编辑器·web
web130933203984 小时前
ctfshow-web入门-文件包含(web82-web86)条件竞争实现session会话文件包含
前端·github
胡西风_foxww4 小时前
【ES6复习笔记】迭代器(10)
前端·笔记·迭代器·es6·iterator