返回顶部
首页 > 资讯 > 前端开发 > VUE >Webpack中Loader和Plugin的区别是什么
  • 670
分享到

Webpack中Loader和Plugin的区别是什么

2024-04-02 19:04:59 670人浏览 安东尼
摘要

这篇文章主要介绍“webpack中Loader和Plugin的区别是什么”,在日常操作中,相信很多人在WEBpack中Loader和Plugin的区别是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用

这篇文章主要介绍“webpack中Loader和Plugin的区别是什么”,在日常操作中,相信很多人在WEBpack中Loader和Plugin的区别是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Webpack中Loader和Plugin的区别是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

Webpack中Loader和Plugin的区别是什么

一、区别

前面两节我们有提到Loader与Plugin对应的概念,先来回顾下

  • loader 是文件加载器,能够加载资源文件,并对这些文件进行一些处理,诸如编译、压缩等,最终一起打包到指定的文件中

  • plugin 赋予了 webpack 各种灵活的功能,例如打包优化、资源管理、环境变量注入等,目的是解决 loader 无法实现的其他事

从整个运行时机上来看,如下图所示:

Webpack中Loader和Plugin的区别是什么

可以看到,两者在运行时机上的区别:

  • loader 运行在打包文件之前

  • plugins 在整个编译周期都起作用

在Webpack 运行的生命周期中会广播出许多事件,Plugin 可以监听这些事件,在合适的时机通过Webpack提供的 api改变输出结果

对于loader,实质是一个转换器,将A文件进行编译形成B文件,操作的是文件,比如将A.sCSS或A.less转变为B.css,单纯的文件转换过程

二、编写loader

在编写 loader 前,我们首先需要了解 loader 的本质

其本质为函数,函数中的 this 作为上下文会被 webpack 填充,因此我们不能将 loader设为一个箭头函数

函数接受一个参数,为 webpack 传递给 loader 的文件源内容

函数中 this 是由 webpack 提供的对象,能够获取当前 loader 所需要的各种信息

函数中有异步操作或同步操作,异步操作通过 this.callback返回,返回值要求为 string 或者 Buffer

代码如下所示:

// 导出一个函数,source为webpack传递给loader的文件源内容 module.exports = function(source) {     const content = doSomeThing2jsString(source);          // 如果 loader 配置了 options 对象,那么this.query将指向 options     const options = this.query;          // 可以用作解析其他模块路径的上下文     console.log('this.context');               this.callback(null, content); // 异步     return content; // 同步 }

一般在编写loader的过程中,保持功能单一,避免做多种功能

如less文件转换成 css文件也不是一步到位,而是 less-loader、css-loader、style-loader几个  loader的链式调用才能完成转换

三、编写plugin

由于webpack基于发布订阅模式,在运行的生命周期中会广播出许多事件,插件通过监听这些事件,就可以在特定的阶段执行自己的插件任务

在之前也了解过,webpack编译会创建两个核心对象:

  • compiler:包含了 webpack 环境的所有的配置信息,包括 options,loader 和 plugin,和 webpack  整个生命周期相关的钩子

  • compilation:作为 plugin  内置事件回调函数的参数,包含了当前的模块资源、编译生成资源、变化的文件以及被跟踪依赖的状态信息。当检测到一个文件变化,一次新的 Compilation  将被创建

如果自己要实现plugin,也需要遵循一定的规范:

  • 插件必须是一个函数或者是一个包含 apply 方法的对象,这样才能访问compiler实例

  • 传给每个插件的 compiler 和 compilation 对象都是同一个引用,因此不建议修改

  • 异步的事件需要在插件处理完任务时调用回调函数通知 Webpack 进入下一个流程,不然会卡住

实现plugin的模板如下:

class MyPlugin {     // Webpack 会调用 MyPlugin 实例的 apply 方法给插件实例传入 compiler 对象   apply (compiler) {     // 找到合适的事件钩子,实现自己的插件功能     compiler.hooks.emit.tap('MyPlugin', compilation => {         // compilation: 当前打包构建流程的上下文         console.log(compilation);                  // do something...     })   } }

在 emit 事件发生时,代表源文件的转换和组装已经完成,可以读取到最终将输出的资源、代码块、模块及其依赖,并且可以修改输出资源的内容

到此,关于“Webpack中Loader和Plugin的区别是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: Webpack中Loader和Plugin的区别是什么

本文链接: https://lsjlt.com/news/70268.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Webpack中Loader和Plugin的区别是什么
    这篇文章主要介绍“Webpack中Loader和Plugin的区别是什么”,在日常操作中,相信很多人在Webpack中Loader和Plugin的区别是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用...
    99+
    2024-04-02
  • webpack的loader和plugin有什么区别
    Webpack的loader和plugin是两个不同的概念,分别用于处理不同的任务。1. Loader(加载器):Loader用于对...
    99+
    2023-10-11
    webpack
  • webpack中loader和plugin的示例分析
    这篇文章主要介绍webpack中loader和plugin的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1 基础回顾首先我们先回顾一下webpack常见配置,因为后面会用到...
    99+
    2024-04-02
  • webpack Plugin的作用是什么
    这篇“webpack Plugin的作用是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“webpack&nbs...
    99+
    2023-06-29
  • webpack中loader有什么用
    这篇文章主要介绍webpack中loader有什么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、loaders之 预处理css-loader 处理css中路径引用等问题styl...
    99+
    2024-04-02
  • babel/plugin-transform-runtime和babel/preset-env的区别是什么
    本篇内容介绍了“babel/plugin-transform-runtime和babel/preset-env的区别是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大...
    99+
    2024-04-02
  • MYSQL中#和$的区别是什么
    小编给大家分享一下MYSQL中#和$的区别是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!他们之间的区别用最直接的话来说就是...
    99+
    2024-04-02
  • MySQL中“:=”和“=”的区别是什么
    小编给大家分享一下MySQL中“:=”和“=”的区别是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!=只有在set和upda...
    99+
    2024-04-02
  • Mybatis中#和$的区别是什么
    这篇文章主要介绍“Mybatis中#和$的区别是什么”,在日常操作中,相信很多人在Mybatis中#和$的区别是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Mybatis中#和$的区别是什么”的疑惑有所...
    99+
    2023-06-22
  • Servlet中/和/*的区别是什么
    这篇文章主要讲解了“Servlet中/和demo:这个urlPatterns是合法的。只不过它属于精确匹配,也就是说别看它中间有*,仍旧有且仅能匹配/api/*/demo这个请求路径匹配顺序有时候一个URL会被多个urlPatterns所匹...
    99+
    2023-06-20
  • Webpack和Vite的区别小结
    目录前言WebpackViteVite相比于Webpack打包更快相比Webpack5中使用的MFSU技术Vite插件推荐总结前言 Webpack和Vite是现代前端开发中非常重要的...
    99+
    2023-05-18
    Webpack Vite
  • 为什么webpack的loader的执行顺序是从后往前
    一、原因 这设计的原因是为了处理代码转换和加载过程中的依赖关系。由于Webpack的模块打包过程是从入口开始递归地解析和加载依赖,然后再进行代码转换,Loader的执行顺序也要与此过程保持一致。 当Webpack遇到需要转换的模块时,它会按...
    99+
    2023-10-29
    是从 顺序 webpack
  • oracle中{}和${}区别是什么
    这篇文章主要介绍“oracle中{}和${}区别是什么”,在日常操作中,相信很多人在oracle中{}和${}区别是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”orac...
    99+
    2024-04-02
  • react和webpack的区别有哪些
    本文小编为大家详细介绍“react和webpack的区别有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“react和webpack的区别有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起...
    99+
    2024-04-02
  • vite和webpack的区别有哪些
    这篇文章主要介绍“vite和webpack的区别有哪些”,在日常操作中,相信很多人在vite和webpack的区别有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vite和webpack的区别有哪些”的疑...
    99+
    2023-07-04
  • php === 和==的区别是什么
    本文操作环境:windows7系统、PHP7.1版、DELL G3电脑php === 和==的区别是什么?php中的==和===的用法及区别在开发中进场遇到数值匹配的问题,那么在进行匹配时,遇到下面的情况,你觉得结果是什么?<php ...
    99+
    2021-03-17
    php
  • ./ 和 sh 的区别是什么
    ./ 和 sh 的区别是什么?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。./ 和 sh的使用区别使用“./”执行脚本,对应的xxx.sh脚本必须要有执行权限;使用“sh”...
    99+
    2023-06-09
  • php中float和double的区别是什么
    本教程操作环境:windows10系统、PHP7.1版、DELL G3电脑php中float和double的区别是什么为了区分 php中float和double的区别,我采用以下代码分别输出。$vad = 1.1; print gettyp...
    99+
    2018-12-12
    PHP
  • php中null和empty的区别是什么
    本文操作环境:Windows10系统、PHP7.1版、Dell G3电脑。php中null和empty的区别是什么null 表示表示一个变量没有值。一个变量为null有三种情况:被赋值为 NULL 。 尚未被赋值。 被 unset() 。e...
    99+
    2021-01-09
    PHP
  • php中get和set的区别是什么
    本教程操作环境:windows10系统、PHP7.1版、DELL G3电脑php中get和set的区别是什么一般来说,总是把类的属性定义为private,这更符合现实的逻辑。但是,对属性的读取和赋值操作是非常频繁的,因此在PHP5中,预定义...
    99+
    2014-11-04
    PHP
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作