【Vue】Parsing error: No Babel config file detected for ... vue

news2024/12/26 22:51:53

报错


Parsing error: No Babel config file detected for E:\Study\Vue网站\实现防篡改的水印\demo02\src\App.vue. Either disable config file checking with requireConfigFile: false, or configure Babel so that it can find the config files.               eslint


背景

  • 开发环境:Windows
  • 开发IDE:Visual Studio Code 版本1.76.0
  • 开发项目:Vue3 - v3.2.13
  • 项目文件夹:E:\Study\Vue网站\实现防篡改的水印\demo02
  • VSCode 插件:ESLint v2.4.2
  • VSCode 打开文件夹:E:\Study\Vue网站\实现防篡改的水印
  • 报错代码:
    在这里插入图片描述

解决方案

方案一、卸载插件

此方法简单粗暴,插件提出问题,解决掉插件也就不会提出问题

方案二、重新打开文件夹

确保项目文件夹VSCode 打开文件夹是同一个文件夹。

原因

  1. package.json的配置文件中,配置eslintConfig\parserOptions\parser的解析器是@babel/eslint-parser
{
  "name": "demo01",
  "version": "0.1.0",
  "private": true,
  "scripts": {
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "lint": "vue-cli-service lint"
  },
  "dependencies": {
    "core-js": "^3.8.3",
    "vue": "^3.2.13"
  },
  "devDependencies": {
    "@babel/core": "^7.12.16",
    "@babel/eslint-parser": "^7.12.16",
    "@vue/cli-plugin-babel": "~5.0.0",
    "@vue/cli-plugin-eslint": "~5.0.0",
    "@vue/cli-service": "~5.0.0",
    "eslint": "^7.32.0",
    "eslint-plugin-vue": "^8.0.3"
  },
  "eslintConfig": {
    "root": true,
    "env": {
      "node": true
    },
    "extends": [
      "plugin:vue/vue3-essential",
      "eslint:recommended"
    ],
    "parserOptions": {
      "parser": "@babel/eslint-parser"
    },
    "rules": {}
  },
  "browserslist": [
    "> 1%",
    "last 2 versions",
    "not dead",
    "not ie 11"
  ]
}

  1. 根据Babel官方手册,Babel 默认从根目录下查找babel.config.js配置,如果打开的文件夹所在的第一级目录没有babel.config.js配置就会报此错。
    在这里插入图片描述

BABEL 配置文件

以下内容从BABEL 配置文件

配置文件类型

Babel 有两种并行的配置文件方式,可以一起使用,也可以单独使用。

▶历史

  • 项目范围的配置
    • babel.config.* 文件,可用如下不同扩展名: .json, .js, .cjs, .mjs
  • 相对文件的配置
    • .babelrc.* 文件,可用如下不同扩展名: .json, .js, .cjs, .mjs
    • 不带扩展名的 .babelrc。`
    • 带有 "babel"`` 属性的 package.json` 文件。

项目范围的配置

Babel 7.x 新版本中,Babel 有一个 "root" 目录的概念, 默认为当前的工作目录文件夹。 对于项目范围的配置,Babel 将在根目录中自动搜索 "babel.config.json" 文件, 或使用了 支持的扩展名 的等效文件。 另外,用户可以使用显式的 "configFile" 值覆盖默认的配置文件搜索行为。

因为项目范围的配置文件与配置文件的物理位置是分离的, 所以它们非常适合必须广泛应用的配置, 甚至允许插件和预设轻松地应用于 node_modules 或符号链接包中的文件, 这在 Babel 6.x 中通常是很难配置的。

项目范围配置的主要缺点是,因为它依赖于工作目录, 如果工作目录不是单体式仓库的根目录,那么在单体式仓库中使用它会更加痛苦。 有关如何在这种上下文中使用配置文件的示例,请参阅 单体式仓库 文档。

也可以通过将 "configFile" 设置为 false 来禁用项目范围的配置。

相对文件的配置

Babel 从正在编译(受以下警告限制)的 "filename" 开始搜索目录结构来加载 .babelrc.json 文件, 或使用了 支持的扩展名 的等效文件。 这种功能非常强大, 因为它允许你为子 package 创建独立的配置。 相对文件的配置可以设置 merged 使它们特定的配置覆盖项目范围的配置值, 尽管这也可以通过 "overrides" 来实现。

当使用相对文件的配置时,需要考虑一些边缘情况:

  • 一旦找到包含 package.json 的目录,搜索就会停止, 因此相对文件的配置仅适用于单个包。
  • 正在编译的 "filename" 必须在 "babelrcRoots" packages 中, 否则搜索将被完全跳过。
  • .babelrc.json 文件仅应用于它们自己包中的文件
  • .babelrc.json 文件将被忽略如果不在 Babel 的 “根” 包中, 除非你选择使用 "babelrcRoots"
    有关如何配置具有多个包的单体式仓库的更多讨论,请参阅 单体式仓库 文档。 还可以通过将 "babelrc" 设置为 false` 来禁用相对文件的配置。

6.x vs 7.x .babelrc 加载

来自 Babel 6.x 的用户可能会遇到这两个边缘情况,这是 Babel 7.x 中的新功能。 这两项限制是为了解决 Babel 6.x 中常见的 footguns 而增加的:

  • .babelrc 文件经常出乎意料地应用于 node_modules 依赖项。
  • .babelrc 文件 无法 应用于符号链接 node_modules,当人们期望它们表现得像正常的依赖时。
  • .babelrc 文件 在 node_modules 依赖关系中将被检测, 即使它们内部的插件和预设通常没有安装, 甚至可能在编译该文件的 Babel 版本中无效。
    这些情况主要会给使用单体式仓库结构的用户造成问题, 如果你有
.babelrc
packages/
  mod1/
    package.json
    src/index.js
  mod2/
    package.json
    src/index.js

该配置现在将被完全忽略,因为它跨越了包边界。

一种替代方法是在每个子包中创建一个 .babelrc,将 "extends" 用作

{ "extends": "../../.babelrc" }

不幸的是,这种方法可能有点重复,根据 Babel 的使用方式, 可能需要设置 "babelrcRoots"

考虑到这一点,将 .babelrc 重命名为 项目范围的 "babel.config.json"可能更可取。 正如上面在项目范围部分提到的, 这可能需要显式设置 "configFile", 因为如果工作目录不正确,Babel 将找不到配置文件。

支持的文件扩展名

可以使用 Node.js 本地支持的任何文件扩展名配置 Babel,正如上面配置文件类型章节提到的一样:

babel.config.json.babelrc.json 被解析为 JSON5,并且应该包含一个 Babel 接受的选项格式匹配的对象。 它们从 v7.7.0 开始支持。

我们建议尽可能使用这种文件类型: 如果你的复杂配置有条件表达式或是在构建时计算的,JS 配置文件则非常方便。 然而,缺点是 JS 配置的静态可分析性较差, 因此对可缓存性、代码检测、IDE 自动完成等有负面影响。 由于 babel.config.json.babelrc.json 是静态 JSON 文件, 因此它允许其他使用 Babel 的工具,如绑定器,安全地缓存 Babel 的结果, 这可能会带来巨大的构建性能优势。

babel.config.cjs.babelrc.cjs 允许你使用 module.exports 将配置定义为 CommonJS。 它们从 v7.7.0 开始支持。

babel.config.mjs.babelrc.mjs 使用原生 ECMAScript 模块。它们在 Node.js 13.2+(或使用 --experimental-modules 标志的更早版本)被支持。 请记住,原生 ECMAScript 模块是异步的(这就是 import() 总是返回 promise 的原因!) 因此,同步调用 Babel 时将抛出 .mjs 配置文件。 它们从 v7.8.0 开始支持。

当你的 package.json 文件包含 "type": "module" 选项时, babel.config.js.babelrc.js 的行为类似 .mjs, 否则它们与 .cjs 文件完全相同。

JavaScript 配置文件可以导出一个对象,也可以导出一个函数, 当调用该函数时,该函数将返回生成的配置。 函数返回配置被赋予一些特殊功能,因为它们可以访问由 Babel 本身公开的 API。 有关更多信息,请参阅 配置函数 API

出于兼容性原因,.babelrc.babelrc.json 的别名。

单体式仓库

单体式结构的仓库通常包含许多包, 这意味着它们通常会遇到 相对文件的配置 和配置文件加载中提到的警告。 本节旨在帮助用户了解如何实现单体式仓库配置。

对于单体式仓库设置,需要理解的核心是 Babel 将你的工作目录作为其逻辑 "root", 如果你想要在特定的子包中运行 Babel 工具,而不希望 Babel 作为一个整体应用于仓库, 则会出现问题。

另外,确定是要使用 .babelrc.json 文件还是只使用中央的 babel.config.json 文件也很重要。 与 Babel 6 一样,子文件夹特定的配置不需要 .babelrc.json 文件, 因此在 Babel 7 中通常不需要这些文件, 而是使用 babel.config.json

babel.config.json 文件

任何单体式仓库结构的第一步都应该是在存储库根目录中创建一个 babel.config.json 文件。 这确立了 Babel 的核心概念,即仓库的基准目录。 即使你想用 .babelrc.json 文件来单独配置每个包, 将其作为仓库级别选项的位置也很重要。

你通常可以将所有仓库配置放在根 babel.config.json 中。 使用 "overrides", 你可以轻松定仅适用于仓库的特定子文件夹的配置, 这通常比在仓库中创建许多 .babelrc.json 文件更容易遵循。

您可能会遇到的第一个问题是,默认情况下, Babel 希望从 "root" 设置的目录加载 babel.config.json 文件, 这意味着如果你创建了一个 babel.config.json, 却在单个包中运行 Babel,例如:

cd packages/some-package;
babel src -d dist

在该上下文中 Babel 使用的 "root" 不是 你仓库的根目录, 它将无法找到 babel.config.json 文件。

如果你所有的构建脚本都是相对于你的仓库根目录运行的,那么应该已经可以工作了, 但是如果你是在子包中运行 Babel 编译过程, 那么你需要告诉 Babel 在哪里查找配置。有几种方法可以做到这一点, 但是推荐的方法是将 "rootMode" 选项设置为 "upward", 这将使 Babel 从工作目录向上搜索 babel.config.json 文件, 并使用其位置作为 "root" 的值。

测试你的配置是否被检测到的一个有用方法是, 如果配置是一个 babel.config.json JavaScript 文件,则在其中放置 console.log() 调用: 日志将在 Babel 第一次加载时执行。

设置这个值的方式因项目而异,但是这里有一些例子:

CLI

babel --root-mode upward src -d lib

@babel/register

require("@babel/register")({
  rootMode: "upward",
});

Webpack

module: {
  rules: [
    {
      loader: "babel-loader",
      options: {
        rootMode: "upward",
      },
    },
  ];
}

Jest

Jest 通常安装在单体式仓库的根目录,可能不需要配置,但是如果它在每个包中都安装,配置起来可能会更加复杂。

主要部分是创建一个自定义 jest transformer 文件,该文件包装 babel-jest 的默认行为,以便设置选项,例如:

module.exports = require("babel-jest").default.createTransformer({
  rootMode: "upward",
});

将其保存在某个位置后,你可以在 Jest 选项中的 transform 选项 中使用处于 babel-jest 位置的这个文件:

"transform": {
  "^.+\\.jsx?$": "./path/to/wrapper.js"
},

因此所有的 JS 文件都将使用你指定的已启用该选项的 babel-jest 版本进行处理。

其他

注意:当使用 babel-jest 等版本时,你必须删除 .default 部分:require("babel-jest").createTransformer({ ...

有很多工具,但最核心的是,如果工作目录还不是单体式仓库的根目录,它们需要启用 rootMode 选项。

子包的 .babelrc.json 文件

类似于 babel.config.json 文件必须位于 "root" 中的方式, .babelrc.json文件必须位于根目录的 package 下。 这意味着,工作目录既会受载入的babel.config.json影响 ,也会受载入的.babelrc.json影响。

假设你已经像上面讨论的那样正确地加载了 babel.config.json 文件,Babel 将只处理根包(而不是子包)中的 .babelrc.json 文件,例如

package.json
babel.config.js
packages/
  mod/
    package.json
    .babelrc.json
    index.js

编译 packages/mod/index.js 文件将不会加载 packages/mod/.babelrc.json 因为 .babelrc.json 位于子包,而不是根包中。

要启用对该 .babelrc.json 的处理,你需要在 babel.config.json 文件中使用 "babelrcRoots" 选项来执行以下操作

babelrcRoots: [
  ".",
  "packages/*",
],

因此 Babel 将认为所有匹配 packages/* 的包与原来的仓库根目录一起,都被允许加载 .babelrc.json 文件。

配置函数 API

JS 配置文件可以导出一个将传递配置函数 API 的函数:

module.exports = function(api) {
  return {};
};

api 对象与配置文件特定的 API 一起暴露了 Babel 本身暴露于其索引模块的所有内容:

api.version

类型:string

正在加载配置文件的 Babel 版本的版本字符串。

api.cache

JS 配置很棒,因为他们可以动态计算配置, 但缺点是它使缓存变得更加困难。Babel 希望避免每次编译文件时都重新执行配置函数, 因为这样还需要重新执行该配置中引用的所有插件和预设函数。

为了避免这种情况,Babel 希望用户在配置函数时告诉它如何管理配置文件中的缓存。

  • api.cache.forever() - Permacache 计算的配置,永远不再调用该函数。

  • api.cache.never() - 不要缓存此配置,并且每次都重新执行该功能。

  • api.cache.using(() => process.env.NODE_ENV) - 根据 NODE_ENV 的值缓存。 每次 using 回调返回的值都不是预期的值,总体而言 将再次调用 config 函数,并将新条目添加到缓存中。

  • api.cache.invalidate(() => process.env.NODE_ENV) - 根据 NODE_ENV 的值缓存。 每次 using 回调返回的值都不是预期的值,总体而言 将再次调用 config 函数,缓存中的所有条目将替换为结果。

  • api.cache(true) - 与 api.cache.forever() 相同

  • api.cache(false) - 与 api.cache.never() 相同
    由于实际的回调结果用于检查缓存条目是否有效,因此建议使用 那:

  • 回调应该小而且没有副作用。

  • 回调应该返回可能的最小范围的值。例如 .using(() => process.env.NODE_ENV)上面的用法并不理想,因为它会造成一个未知的 高速缓存条目的数量取决于检测到多少个 NODE_ENV 值。 .using(() => process.env.NODE_ENV === "development") 更安全,因为缓存条目 只能是 true 或 false。

api.env(…)

由于 NODE_ENV 是一种相当常见的切换行为方式,因此 Babel 还包含一个 API 函数 专门为此而设。此 API 用作检查的快速方法 加载了 Babel"envName",将 NODE_ENV 考虑在内 如果没有设置其他覆盖环境。

它有几种不同的形式:

  • api.env(“production”) 返回 true 如果 envName === “production”.
  • api.env(["development", "test"]) 返回 true 如果 ["development", "test"].includes(envName).
  • api.env() 返回当前的 envName 字符串。
  • api.env(envName => envName.startsWith("test-")) 如果 env"test-" 开头,则返回 true

注意: 这个函数在内部使用上面提到的 api.cache 来确保 Babel 知道这个构建依赖于特定的 envName。您不应该将它和 api.cache.forever() 或者 api.cache.never() 一起使用。

api.caller(cb)

API 用作访问已传递给 Babelcaller 数据的方法。 由于 Babel 的许多实例可能在不同的 caller 的同一进程中运行 值,这个 API 旨在自动配置 api.cache,就像 api.env() 一样。

caller 值可用作回调函数的第一个参数。 最好用有类似的东西

function isBabelRegister(caller) {
  return !!(caller && caller.name === "@babel/register");
}

module.exports = function(api) {
  const isRegister = api.caller(isBabelRegister);

  return {
    // ...
  };
};

根据特定环境切换配置行为。

api.assertVersion(range)

虽然 api.version 在一般情况下很有用,但有时候声明你的版本会很好。 此 API 公开了一种简单的方法:

module.exports = function(api) {
  api.assertVersion("^7.2");

  return {
    // ...
  };
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/842661.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

23年电赛D题-信号调制方式识别与参数估计装置

红叶何时落水 题目 题目分析 该题目的是制作一个信号检测以及解调装置 主要的任务有三个 1.六种信号的识别 2.信号相关参数的测量 3.信号解调 任务一 识别信号有很多思路,最简单的方式便是通过对信号进行FFT分析,分析其中的各个谐波的特征值。 …

自动化测试CSS元素定位

目录 1.1 CSS定位 1.1.1 绝对路径定位 1.1.2 相对路径定位 1.1.3 类名定位 1.1.4 属性定位 1.1.4.1 ID属性定位 1.1.4.2 其他属性定位 1.1.4.3 模糊属性定位 1.1.5 子页面元素查找 1.1.6 伪类定位 1.1 CSS伪类 1.1 CSS定位 1.1.1 绝对路径定位 目标 查找第一个文…

CS 144 Lab Seven -- putting it all together

CS 144 Lab Seven -- putting it all together 引言测试lab7.ccUDPSocketNetworkInterfaceAdapterTCPSocketLab7main方法子线程 小结 对应课程视频: 【计算机网络】 斯坦福大学CS144课程 Lab Six 对应的PDF: Checkpoint 6: putting it all together 引言 本实验无需进行任何编…

HubSpot网页设计神器,你想要的Landing Page都在这里!

在当今数字化时代,Landing Page(落地页)已成为营销策略中不可或缺的一环。它是与潜在客户首次接触的窗口,能够直接影响转化率和销售结果。而作为一款领先的营销自动化工具,HubSpot为企业提供了打造引人注目的Landing P…

uniapp微信小程序 401时重复弹出登录弹框问题

APP.vue 登陆成功后,保存登陆信息 if (res.code 200) {uni.setStorageSync(loginResult, res)uni.setStorageSync(token, res.token);uni.setStorageSync(login,false);uni.navigateTo({url: "/pages/learning/learning"}) }退出登录 toLogout: func…

Spring Cloud 的版本和SpringBoot的版本

Spring Cloud 的版本选择 Spring Cloud 和SpringBoot的版本存在对应关系 Spring Cloud 的版本和SpringBoot的版本,存在对应关系。最新的SpringCloud版本(发布文章时为2022.0.3),需要SpringBoot(3.0.9) 的…

爬虫获取电影数据----以沈腾参演电影为例

数据可视化&分析实战 1.1 沈腾参演电影数据获取 文章目录 数据可视化&分析实战前言1. 网页分析2. 构建数据获取函数2.1 网页数据获取函数2.2 网页照片获取函数 3. 获取参演影视作品基本数据4. 电影详细数据获取4.1 导演、演员、描述、类型、投票人数、评分信息、电影海…

【云原生】Docker-compose中所有模块学习

compose模块 模板文件是使用 Compose 的核心,涉及到的指令关键字也比较多。但大家不用担心,这里面大部分指令跟 docker run 相关参数的含义都是类似的。 默认的模板文件名称为 docker-compose.yml,格式为 YAML 格式。 version: "3&quo…

STM32基础入门学习笔记:内部高级功能应用

文章目录: 一:低功耗模式 1.睡眠模式测试程序 NVIC.h NVIC.c key.h key.c main.c 2.停机模式测试程序 main.c 3.待机模式测试程序 main.c 二:看门狗 1.独立看门狗测试程序 iwdg.h iwdg.c main.c 2.窗口看门狗测试程序 wwdg…

Unity面板究极优化

首先对于大项目来说UI首选一定的UGUI,目前没有啥可选的余地。多一点都是对性能的负担,UGUI底层基于多线程技术,可以有效分担压力,对于一些不是那么重的面板几乎无感。 无论其他面板只是在此基础上修改的,但每多一层&am…

机器学习---监督学习和非监督学习

根据训练期间接受的监督数量和监督类型,可以将机器学习分为以下四种类型:监督学习、非监督学习、半监督学习和强化学习。 监督学习 在监督学习中,提供给算法的包含所需解决方案的训练数据,成为标签或标记。 简单地说,…

40.利用欧拉法求解微分方程组(matlab程序)

1.简述 求解微分方程的时候,如果不能将求出结果的表达式,则可以对利用数值积分对微分方程求解,获取数值解。欧拉方法是最简单的一种数值解法。前面介绍过MATLAB实例讲解欧拉法求解微分方程,今天实例讲解欧拉法求解一阶微分方程组。…

简单认识ELK日志分析系统

一. ELK日志分析系统概述 1.ELK 简介 ELK平台是一套完整的日志集中处理解决方案,将 ElasticSearch、Logstash 和 Kiabana 三个开源工具配合使用, 完成更强大的用户对日志的查询、排序、统计需求。 好处: (1)提高安全…

OnlyOffice社区版破解最大连接限制部署

onlyoffice社区版部署并且破解最大连接数 docker镜像 docker pull onlyoffice/documentserver:5.3.1.265.4或更高的版本已经解决了此方法的Bug 运行镜像 docker run -d --name onlyoffice --restartalways -p 暴露端口号:80 onlyoffice/documentserver:5.3.1.26进入容器内部…

windows系统安装ElasticSearch7.9.3笔记

windows系统安装ElasticSearch7.9.3笔记 从es中文社区 或elastic官网下载安装包 ES中文社区-浏览器地址https://elasticsearch.cn/download/ 下载7.9.3版本的相关安装包 下载的安装包清单如下 开始配置使用带ik分词器和拼音分词器的ES7.9.3 分别解压这3个zip 拷贝ik分词器…

48.C++ vector容器(模板类)

今天学习了C中的vector容器,它提供动态数组功能,方便管理和存储数据。支持动态调整大小,简化了数组操作,使代码更灵活、高效。实在是太牛了,后悔没有早点学习容器。 目录 一、vector简介 二、头文件和命名空间 三…

该你出手了!华为云PaaS服务 8月线上开发者活动指南——技术提升、合作交流、创新无限!

天高云阔、风朗气清 亲爱的开发者们,8月已经来临 你们准备好迎接一个充满激情和挑战的月份了吗? 如果你对编程充满热情,对技术前沿有所追求 那么华为云PaaS为各位开发者准备的这些8月活动,你一定不能错过。 为了让开发者们更好…

集睿致远/CS5269设计Typec转HDMI带PD100w快充方案

集睿致远ASL推出的CS5269AN是一款高性能Typec/DP1.4转HDMI 4k_60Hz带PD100w快充转换器方案芯片 DP接口包括4条主通道、辅助通道和HPD信号。支持5.4Gbps(HBR2)的数据速率。DP接收机兼容HDCP1.4和HDCP2.3内容保护方案具有嵌入式密钥,用于数字音视频内容的…

【源码分析】Nacos如何使用AP协议完成服务端之间的数据同步?

AP节点的同步使用的是异步任务消息队列的方式来实现的。 取出任务之后将会放入到一个List集合中。 然后会发现任务的执行是由条件的。 首先是当前集群的节点数量等于1000,那么此时会直接开始同步,当然这个条件在小项目中不会成立,所以还有…

BIO,NIO,AIO总结

文章目录 1. BIO (Blocking I/O)1.1 传统 BIO1.2 伪异步 IO1.3 代码示例 1.4 总结2. NIO (New I/O)2.1 NIO 简介2.2 NIO的特性/NIO与IO区别1)Non-blocking IO(非阻塞IO)2)Buffer(缓冲区)3)Channel (通道)4)Selector (选择器) 2.3 NIO 读数据和写数据方式…