我的编程空间,编程开发者的网络收藏夹
学习永远不晚

ESLint和Jest中使用esm示例详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

ESLint和Jest中使用esm示例详解

package.json 配置 type 选项

node.js 已经支持了 esm 的模式,写 esm 需求开始大于 commonjs 的需求。但问题一些库对 esm 支持相对较慢。下面盘点:eslint 和 jest 中使用 esm 遇到的问题。

{
  "name": "debugger-source-code",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "type": "module",
  "scripts": {},
  "keywords": [],
  "author": "",
  "license": "ISC",
  "dependencies": {}
}

告诉这个项目使用 esm 的方式来处理。

eslint 支持 esm 配置

eslint 支持 esm 有两种方式:

  • 环境变量使用浏览器环境,支持高阶的 ECMAScript 的语法。
  • 使用处在实验性的 eslint.config.js 文件输出 esm 配置文件。
npm init @eslint/config # 使用命令初始化 eslint 的配置

eslint 命令使用问答的方式生成一个配置文件。我们选择的时候按照浏览器 esm 的选项进行选择,得到的一个 .eslintrc.cjs

module.exports = {
    "env": {
        "browser": true,
        "es2021": true
    },
    "extends": "eslint:recommended",
    "overrides": [
    ],
    "parserOptions": {
        "ecmaVersion": "latest",
        "sourceType": "module"
    },
    "rules": {
    }
}

注意 后缀时 .cjs 的内容, 输出的是一个 commonjs 的模块的配置文件,在现有的版本中是不支持的 esm 的配置文件,如果配置文件被编辑器报了非 esm 错误,可以将配置文件添加到 .eslintignore 文件中,或者使用其他类型文件配置项目。

使用 eslint.config.js

eslint 在新的版本中,实验性开始支持 eslint.config.js 文件,此文件需要输出一个 esm 的模块,这里不讲配, 一个简单的配置如下:

export default [
    {
        rules: {
            semi: "error",
            "prefer-const": "error"
        }
    }
]

jest 中使用 esm

当然这里不考虑扩展 js 语法到 JSX/TSX 等其他拓展文件,原生使用 esm 的语法

npm install jest

如果只是普通的 JS esm 语法其实不用配置 Jest, 但是需要启动 Jest 的时候添加 Node.js 的属性支持

"scripts": {
    "test": "NODE_OPTIONS=--experimental-vm-modules jest"
}

使用 jsx 语法 esm 支持

这里我们还是使用 babel, 使用 babel 的流程如下:

  • 安装 babel 以及其它依赖包: babel-jest、@bable/core、@babel/preset-env、@babel/preset-react
  • 配置 babel 配置配置文件;
module.exports = {
  presets: [['@babel/preset-env', {targets: {node: 'current'}}], '@babel/preset-react'],
};

修改 jest 的转换器:

export default {
  transform: {
    '\\.[jt]s?$': 'babel-jest' // babel-jest 来转换
  },
};

小结

  • eslint 支持 esm 中遇到的问题以及解决方法
  • jest 中使用 esm 的两种方式

参考

  • ESLint Config file
  • Eslint new Config
  • Jest transform

以上就是ESLint和Jest中使用esm示例详解的详细内容,更多关于ESLint Jest使用esm的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

ESLint和Jest中使用esm示例详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

ESLint和Jest中使用esm示例详解

这篇文章主要为大家介绍了ESLint和Jest中使用esm示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-03-03

ESLint和Jest中怎么使用esm

本篇内容介绍了“ESLint和Jest中怎么使用esm”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!package.json 配置 type
2023-07-05

TreeSet详解和使用示例

TreeSet是Java集合框架中的一个类,它实现了SortedSet接口,底层使用红黑树实现,可以实现有序的插入和遍历。TreeSet的特点:1. TreeSet中的元素是有序的,默认按照升序排序,也可以通过Comparator自定义排序
2023-08-08

Android SlidingMenu使用和示例详解

很多APP都有侧滑菜单的功能,部分APP左右都是侧滑菜单~SlidingMenu 这个开源项目可以很好帮助我们实现侧滑功能,如果对SlidingMenu 还不是很了解的童鞋,可以参考下本篇博客。将侧滑菜单引入项目的方式很多中,本博客先通过例
2022-06-06

Promise.race和Promise.any使用示例详解

这篇文章主要为大家介绍了如何使用Promise.race()和Promise.any()示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

npmscript和package-lock.json使用示例详解

这篇文章主要为大家介绍了npmscript和package-lock.json使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-02-02

Golang中context包使用场景和示例详解

这篇文章结合示例代码介绍了context包的几种使用场景,文中有详细的代码示例,对学习或工作有一定的帮助,需要的朋友可以参考下
2023-05-19

Golang中context包使用场景和示例详解

Golangcontext包使用场景Golangcontext包提供了一种机制,可以在goroutine之间传递上下文信息,包括取消信号、截止日期和值。它可用于处理各种场景,例如:取消操作设置截止日期传递值具体示例:取消操作:import"context"ctx,cancel:=context.WithCancel(context.Background())//取消上下文cancel()设置截止日期:import"context"ctx,cancel:=context.WithTimeout(contex
Golang中context包使用场景和示例详解
2024-04-23

Android中ExpandableListView使用示例详解

本文实例为大家分享了ExpandableListView使用示例,供大家参考,具体内容如下MainActivity:public class Expandable_test extends Activity { private Expan
2023-05-30

MySQL 中 LIMIT 使用示例详解

mysql是一种常用的关系型数据库管理系统,它提供了许多用于查询和操作数据的功能。其中,LIMIT是一个非常有用的关键字,用于在查询结果中限制返回的行数。操作数据库时,经常会遇到需要查询前几条或者后几条数据的javascript情况,尤
MySQL 中 LIMIT 使用示例详解
2024-08-12

iOS中NSThread使用示例详解

这篇文章主要为大家介绍了iOS中NSThread使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

C++的new和delete使用示例详解

这篇文章主要为大家介绍了C++的new和delete使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-12-08

Rust语言中的String和HashMap使用示例详解

这篇文章主要介绍了Rust语言中的String和HashMap使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

Go语言中goroutine和WaitGroup的使用示例详解

goroutine是Go中一个轻量级的线程,只需要一个go关键字就可以创建一个goroutine,这篇文章主要介绍了Go语言中goroutine和WaitGroup的使用,需要的朋友可以参考下
2023-03-03

编程热搜

目录