首页 > 其他分享 >webpack(概念)

webpack(概念)

时间:2023-12-25 23:22:49浏览次数:40  
标签:插件 module js 概念 webpack path loader

入口(entry

入口起点(entry point)指示webpack打包起点。构建依赖图(dependency graph)的开始。

默认值是 ./src/index.js。可以配置,如下:

webpack.config.js

module.exports = {
  entry: './path/to/my/entry/file.js',
};

输出(output)

output告诉webpack在哪里输出它所创建的 bundle,以及如何命名这些文件。主要输出文件的默认值是 ./dist/main.js,其他生成文件默认放置在 ./dist 文件夹中。

webpack.config.js

const path = require('path');

module.exports = {
  entry: './path/to/my/entry/file.js',
  output: {
    path: path.resolve(__dirname, 'dist'),
    filename: 'my-first-webpack.bundle.js',
  },
};

loader

webpack 只能理解 JavaScript 和 JSON 文件,这是 webpack 开箱可用的自带能力。loader 让 webpack 能够去处理其他类型的文件,并将它们转换为有效 模块,以供应用程序使用,以及被添加到依赖图中。

在 webpack 的配置中,loader 有两个属性:

  1. test 属性,识别出哪些文件会被转换。
  2. use 属性,定义出在进行转换时,应该使用哪个 loader。
const path = require('path');

module.exports = {
  output: {
    filename: 'my-first-webpack.bundle.js',
  },
  module: {
    rules: [{ test: /\.txt$/, use: 'raw-loader' }],
  },
};

以上配置中,对一个单独的 module 对象定义了 rules 属性,里面包含两个必须属性:test 和 use。这告诉 webpack 编译器(compiler) 如下信息:

  • “嘿,webpack 编译器,当你碰到「在 require()/import 语句中被解析为 '.txt' 的路径」时,在你对它打包之前,先 use(使用) raw-loader 转换一下。”

在 webpack 配置中定义 rules 时,要定义在 module.rules 而不是 rules 中。

插件(plugin)

 插件则可以用于执行范围更广的任务。包括:打包优化,资源管理,注入环境变量。 想要使用一个插件,你只需要 require() 它,然后把它添加到 plugins 数组中。多数插件可以通过选项(option)自定义。你也可以在一个配置文件中因为不同目的而多次使用同一个插件,这时需要通过使用 new 操作符来创建一个插件实例。
const HtmlWebpackPlugin = require('html-webpack-plugin');
const webpack = require('webpack'); // 用于访问内置插件

module.exports = {
  module: {
    rules: [{ test: /\.txt$/, use: 'raw-loader' }],
  },
  plugins: [new HtmlWebpackPlugin({ template: './src/index.html' })],
};

模式(mode)

 通过选择 developmentproduction 或 none 之中的一个,来设置 mode 参数,你可以启用 webpack 内置在相应环境下的优化。其默认值为 production

浏览器兼容性(browser compatibility)

Webpack 支持所有符合 ES5 标准 的浏览器(不支持 IE8 及以下版本)。webpack 的 import() 和 require.ensure() 需要 Promise。如果你想要支持旧版本浏览器,在使用这些表达式之前,还需要 提前加载 polyfill

环境(environment)

Webpack 5 运行于 Node.js v10.13.0+ 的版本。

 

原文:https://webpack.docschina.org/concepts/#entry

标签:插件,module,js,概念,webpack,path,loader
From: https://www.cnblogs.com/withheart/p/17927182.html

相关文章

  • 12.15数学学习笔记——1.1集合的概念
    把研究对象统称为元素,把一些元素组成的总体叫做集合。给定一个集合,那么一个元素在或者不在这个集合中就确定了。一个给定集合中的元素是互不相同的(集合中的元素是不重复出现的)。只要构成两个集合的元素是一样的,我们就称这两个集合是相等的。如果说a是集合A的元素,就说a属于集合......
  • C# 线程、线程池、Task概念+代码实践 C# 线程、线程池、Task概念+代码实践
    C#线程、线程池、Task概念+代码实践dotnet编程大全专注C#wpf开发,dotnet编程大全 1人赞同了该文章转自:JerryMouseLihttp://cnblogs.com/JerryMouseLi/p/14135600.html前言 线程中的概念很多,如果没有代码示例来理解,会比较晦涩,而且有些概......
  • 二叉树 - 基本概念
    1.树的基本概念与数组链表不同,树是一种非线性的存储结构,它由n(n>=0)个节点构成并具有层次关系的存储结构把这个存储结构叫做树是因为它看上去像一颗倒挂着的树,只是根在上叶子在下它有以下特性:1. 有一个特殊的结点,称为根结点,根结点没有前驱结点2.树是由若干不相交的......
  • 人工智能入门实战:语音识别的基本概念与实践
    1.背景介绍语音识别,也被称为语音转文本(Speech-to-Text),是人工智能领域中的一个重要技术。它能够将人类的语音信号转换为文本,从而实现人机交互的能力。随着人工智能技术的发展,语音识别技术已经广泛应用于智能家居、智能汽车、虚拟助手、语音搜索等领域。在本篇文章中,我们将从以下几个......
  • 1-性能测试中的概念与主要指标
    转换思维:性能测试不再是找bug,而在找性能指标。性能测试一定要用工具,因为要模拟多用户操作。性能测试:通过工具,找出或获得系统不同工况下的性能指标。负载测试(“看看你有几斤几两”):逐步增加系统负载,测试系统性能变化,并最终确定系统所能承受的最大负载量。超出最大负载量,就容易出......
  • BMS的基本概念
    BMS简介 概念背景:电动车的电瓶电池有时候使用的正是锂电池,这种电池材料存在一定的特性,使其不能被过充、过放、过流、短路及超高低温充放电,因此锂电池组总会有一块精致的BMS相伴,BMS指的是是BatteryManagementSystem电池管理系统,也叫保护板。定义:BMS电池系统俗称之为电池......
  • 【转载】内存基本概念-伙伴(Buddy)算法
    简介​在Linux系统中,内存的分配与回收速率直接影响系统的存取效率。当内核频繁请求和释放不同大小的一组连续页框时,会导致许多外部空闲碎片,造成空间的浪费。使用伙伴算法可以有效地缓解该问题。伙伴关系机制是操作系统中的一种动态存储管理算法。在进行内存分配时,该算法通过......
  • 【转载】内存基本概念-watermark&lowmem_reserve
    概述当系统内存短缺的情况下仍去申请内存,可能会触发系统对内存的回收,那什么时候应该进行回收,回收到什么标准又可以停止回收,参考依据是什么?即本文将介绍的watermark(内存水位线),当检查watermark时又不单单是判断watermark,还会牵扯到lowmem_reserve[],关于lowmem_reserve本文会一并......
  • 【转载】内存基本概念-slab算法
    Linux内存管理之slab2:slabAPIhttps://blog.csdn.net/lqy971966/article/details/1198019121.为什么有了Buddy(伙伴系统)还需要slab?1.1什么是伙伴系统?Linux内核中使用伙伴系统(buddysystem)算法以页为单位管理内存,进行内存分配。1.1.1伙伴系统思想它把所有的空闲页放到1......
  • 【转载】内存基本概念-node, zone ,page
    1.Linux描述物理内存在linux内存管理(一)中介绍了UMA和NUMA,Linux通过巧妙办法把UMA和NUMA的差别隐藏了起来,所谓的UMA其实就是只有一个结点的NUMA。内存的每个结点关联到系统中的一个处理器内存控制器,每个服务器处理器可以有多个内存控制器,所以每个服务器处理器可以有多个内存结......