npm 包 @oasisdigital/rollup-plugin-node-resolve 使用教程

简介

@oasisdigital/rollup-plugin-node-resolve 是 Rollup 的一个插件,用于解析模块依赖关系。它通过 node-resolvenode_modules 目录中查找模块,与 rollup-plugin-commonjs 一起使用可以让 Rollup 打包更多的模块。

安装

使用 npm 进行安装:

--- ------- ---------------------------------------- ----------

使用

在配置文件中引入该插件并添加到 plugins 数组中即可使用。示例:

------ ------- ---- ------------------------------------------

------ ------- -
  ------ --------------
  ------- -
    ----- -----------------
    ------- -------
  --
  -------- -
    --------- -------- ----- --------------- ----- --
  -
-

以上示例中,我们设置了 browser: true 来指定插件使用浏览器版本的 Node.js 核心模块,而不是原始 Node.js 版本。另外,我们设置了 preferBuiltins: false 来禁用自动使用核心模块而不解析。

参数说明

使用 resolve() 初始化插件时可以传入一些参数来进行配置。

browser

  • Type: boolean
  • Default: false

如果为 true,则使用浏览器版本的 Node.js 核心模块,而不是原始 Node.js 版本。

mainFields

  • Type: Array
  • Default: ['module', 'jsnext:main', 'main']

定义了按优先级解析的字段列表。按以下顺序查找入口文件:

  1. module
  2. jsnext:main
  3. main

preferBuiltins

  • Type: boolean
  • Default: true

如果为 true,则自动使用核心模块而不解析。如果为 false,则不自动使用核心模块。

示例代码

假设我们有以下依赖关系:

-------
--- ------
--- ------

我们可以使用 @oasisdigital/rollup-plugin-node-resolve 插件解析这些模块:

------ ------- ---- ------------------------------------------

------ ------- -
  ------ --------------
  ------- -
    ----- -----------------
    ------- -------
  --
  -------- -
    --------- -------- ----- --------------- ----- --
  -
-

在本例中,我们开启了 browser 配置选项,默认情况下,插件使用 node 选项,这意味着插件将使用 Node.js 内置的核心模块解析依赖项。

这里我们还配置了 preferBuiltinsfalse,这意味着插件不会使用 Node.js 内置的核心模块来解析依赖项。由于我们已经开启了 browser 配置选项,任何尝试使用 Node.js 内置的核心模块的语句都将自动转换为使用浏览器支持的版本。

这里我们使用一个简单的示例代码作为入口:

-- -----------
------ ------ ---- --------
------ - ---- --------

--------------------------------

使用命令 rollup -c 进行打包后,我们可以在 dist/bundle.js 中看到打包后的代码:

--------- -- -
  ---- --------

  --- ------ - --------------

  --- --------- - -----------------

  ---------------------------------
-----

我们可以看到插件使用了浏览器版本的 momentlodash,而且还转换了核心模块的语句。打包后的代码可以在浏览器中直接使用。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/6005739e81e8991b448e9948


猜你喜欢

  • npm 包 vue2-iscroll 使用教程

    前言 随着移动端设备的普及,移动端应用已经成为了日常生活中不可缺少的一部分。而在移动端应用中,滚动功能是十分常见且重要的。而 iScroll 是一款非常出色、易用并且兼容性极佳的滚动插件,它为用户提供...

    3 年前
  • npm 包 @hasaki-ui/hsk-alistar 使用教程

    简介 @hasaki-ui/hsk-alistar 是一个 React 组件库,以及配套的样式库,提供了一些简单实用的组件,可帮助您快速创建 React 应用程序。

    3 年前
  • npm 包 flagwind-echarts 使用教程

    介绍 flagwind-echarts 是一个基于 echarts 的数据可视化解决方案,它提供了一些常用的图表组件,可以帮助前端开发者快速创建数据可视化的应用。 flagwind-echarts 的...

    3 年前
  • npm 包 `vue-touch-feedback-plugin` 使用教程

    前言 前端开发涉及到的技术日新月异,我们应该及时了解和学习新的技术和工具。本文将介绍一款名为 vue-touch-feedback-plugin 的 npm 包,在移动端开发中为用户提供更良好的操作反...

    3 年前
  • npm 包 @thinman/koa-joi-router 使用教程

    在前端开发中,使用 npm 包可以提高开发效率和代码质量,因为它们提供可重用和可维护的 JavaScript 模块。在本文中,我们将介绍使用一个 npm 包 @thinman/koa-joi-rout...

    3 年前
  • npm 包 @rxcc/debug 使用教程

    前言 在前端开发中,调试是一个不可避免的环节。我们常常使用 console.log() 来进行调试,但是在大型的项目中,使用 console.log() 很容易出现问题,因为此时可能会有很多输出,甚至...

    3 年前
  • npm 包 hyperapp-webpack-hmr 使用教程

    前言 hyperapp 是一个轻量级的前端框架,适用于构建单页应用程序。然而在实际开发中,我们通常需要将我们的程序构建成可发布的静态文件,这时候就需要使用到 webpack。

    3 年前
  • npm 包 icpi-algorithm 使用教程

    前端开发离不开算法,它可以帮助我们更好地完成一些复杂的任务,提高代码的效率和质量。而 npm 包 icpi-algorithm 就是一个专门为前端开发人员提供的算法工具包,它包含了很多常用的算法,如排...

    3 年前
  • npm 包 ideatica-unzip 使用教程

    在前端开发的过程中,我们常常需要对压缩文件进行操作。npm 包 ideatica-unzip 是一个轻量级的 Node.js 模块,它可以帮助我们轻松地将 ZIP 文件解压到指定目录中。

    3 年前
  • npm 包 openui5-camera 使用教程

    前言 在前端开发中,我们经常需要让用户上传图片或者使用摄像头拍照。而在移动应用开发中,直接调用原生摄像头 API 可能有一定风险,并且不同平台的API有所不同。openui5-camera 这个 np...

    3 年前
  • npm 包 @rxcc/helpers 使用教程

    在日常的前端开发中,我们经常需要完成一些重复性的工作,例如字符串操作、数据格式化等等。这些操作可以使用一些工具函数来简化我们的编码过程。npm 包 @rxcc/helpers 就是为了解决这些问题而存...

    3 年前
  • npm 包 react-simple-progress 使用教程

    前端开发中,大多数产品都需要加载进度条来提高用户体验。而 react-simple-progress 就是一款简单易用的进度条组件。它提供了多种进度条样式,可以轻松自定义进度条的颜色、宽度、高度等属性...

    3 年前
  • npm 包 @vectorspace/babel-preset 使用教程

    在前端开发中,Babel 是一款非常常用的 JavaScript 转码器,可以将 ECMAScript 6 代码转换为浏览器可以执行的 JS 代码。但是,在使用 Babel 进行代码转换时,我们需要配...

    3 年前
  • npm 包 @vectorspace/eslint-config 使用教程

    在前端开发中,代码风格一直是大家非常关注的问题。ESLint 是一个被广泛应用和使用的 JavaScript 代码检查工具,它能够帮助我们避免 JavaScript 代码中的基本语法错误,加强代码风格...

    3 年前
  • npm 包 @vectorspace/jest-preset 使用教程

    在前端开发中,自动化测试是非常重要的一环。而 Jest 是一个开源的 JavaScript 测试框架,它可以帮助我们轻松地编写测试用例,并且提供了简单易用的命令行工具。

    3 年前
  • npm包 detect-content-type 使用教程

    在前端开发中,经常需要处理各种类型的文件,其中一项基础工作就是确定一个文件的内容类型(MIME type),从而正确地处理这个文件。npm包 detect-content-type 就提供了这样的功能...

    3 年前
  • npm 包 helio-angular-gridster 使用教程

    前言 在现代 Web 前端开发中,很多时候我们需要使用各种各样的组件库来加速开发。其中, helio-angular-gridster 是一个很棒的 Angular Gridster 组件库,它提供了...

    3 年前
  • npm 包 ops-select-range 使用教程

    什么是 ops-select-range? ops-select-range 是一个开源的前端组件,通过它可以方便地操作 DOM 中的选区。它可以帮助开发者实现各种与选区相关的功能,例如文字样式的修改...

    3 年前
  • npm 包 preacher 使用教程

    npm 是 Node.js 的包管理器,其中有很多优秀的开源前端包供我们使用。其中,preacher 是一个可以让我们更好地阐述项目目的、逻辑以及解决方案的 npm 包。

    3 年前
  • npm 包 proximiio-cordova 使用教程

    前言 proximiio-cordova 是一款基于 Cordova 平台的 npm 包。它提供了与 proximi.io 室内定位服务平台的集成支持,并为开发者提供了简单易用的接口。

    3 年前

相关推荐

    暂无文章