ESLint 中的“ space-before-function-paren ”相关报错及其解决方案

2023-11-29 00:10

本文主要是介绍ESLint 中的“ space-before-function-paren ”相关报错及其解决方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

出现的问题及其报错:

 报错原因:

解决方案:

方案一: 

方案二: 

方案三: 

 注意: 三种方案只可以使用一种,看自己的需求,三种方案会有一种适合你的报错

想知道解决方案的原理,可以阅读 space-before-function-paren 规则,如下

space-before-function-paren 规则:

规则细节

选项

“always”

“never”

{"anonymous": "always", "named": "never", "asyncArrow": "always"}

{"anonymous": "never", "named": "always"}

{"anonymous": "ignore", "named": "always"}

何时不使用

相关规则

版本


出现的问题及其报错:

在 VScode 中,在使用带有 ESLint 工具的项目中,保存会发现报错,并且修改好代码格式后,保存会发现代码格式依然出现问题:

 报错原因:

 “ space-before-function-paren ” 英文 翻译为 中文 为“函数参数前的意外空格

报这个错误的原因是 函数名称 或 function关键字 与开始参数之间缺少空格(或多出空格),可以通过修改 eslint 的配置文件来更改语法检测规则

在--fix命令行上的选项可以自动修复一些被这条规则反映的问题。

格式化函数时,函数名称或function关键字与开始参数之间允许有空格。命名函数还需要function关键字和函数名称之间的空格,但匿名函数不需要空格。

解决方案:

方案一: 

打开 .eslintrc.js 文件,并在  rules 中添加如下一行代码即可:

 "space-before-function-paren": 0,

方案二: 

 打开 .eslintrc.js 文件,并在  rules 中添加如下一行代码即可:

'space-before-function-paren': ['error', 'never', { anonymous: 'always', named: 'always', asyncArrow: 'always' }],

方案三: 

 打开 .eslintrc.js 文件,并在  rules 中添加如下一行代码即可:

'space-before-function-paren': ['error', 'never'],

以上三种方案都试过后,其中会有一种方法就可以解决问题啦 ,这是最快的解决方案,每个都尝试一遍;

 注意: 三种方案只可以使用一种,看自己的需求,三种方案会有一种适合你的报错

想知道解决方案的原理,可以阅读 space-before-function-paren 规则,如下

space-before-function-paren 规则:

在  --fix 命令行上的选项可以自动修复一些被这条规则反映的问题。

格式化函数时,函数名称或  function 关键字与开始参数之间允许有空格。命名函数还需要  function 关键字和函数名称之间的空格,但匿名函数不需要空格。例如:

function withoutSpace(x) {// ...
}function withSpace (x) {// ...
}var anonymousWithoutSpace = function() {};var anonymousWithSpace = function () {};

样式指南在  function 匿名函数的关键字之后可能需要一个空格,而另一些则不指定空白。同样,函数名称后面的空格可能需要也可能不需要。

规则细节

此规则旨在在函数括号之前强制执行一致的间距,因此,只要空格不符合指定的偏好,就会发出警告。

选项

此规则具有字符串选项或对象选项:

{"space-before-function-paren": ["error", "always"],// or"space-before-function-paren": ["error", {"anonymous": "always","named": "always","asyncArrow": "always"}],
}
  • always(默认)需要一个空格,然后(是参数。
  • never(参数后面不允许任何空格。

        字符串选项不会检查异步箭头函数表达式的向后兼容性。

        您还可以为每种类型的功能使用单独的选项。下列选项每一个都可以被设置为"always""never""ignore"。默认是"always"

  • anonymous是用于匿名函数表达式(例如function () {})。
  • named是用于命名函数表达式(例如function foo () {})。
  • asyncArrow是用于异步箭头函数表达式(例如async () => {})。

“always”

此规则的默认代码错误代码示例"always"

/*eslint space-before-function-paren: "error"*/
/*eslint-env es6*/function foo() {// ...
}var bar = function() {// ...
};var bar = function foo() {// ...
};class Foo {constructor() {// ...}
}var foo = {bar() {// ...}
};var foo = async() => 1

具有默认选项的此规则的正确代码示例"always"

/*eslint space-before-function-paren: "error"*/
/*eslint-env es6*/function foo () {// ...
}var bar = function () {// ...
};var bar = function foo () {// ...
};class Foo {constructor () {// ...}
}var foo = {bar () {// ...}
};var foo = async () => 1

“never”

此规则的错误代码示例包含以下"never"选项:

/*eslint space-before-function-paren: ["error", "never"]*/
/*eslint-env es6*/function foo () {// ...
}var bar = function () {// ...
};var bar = function foo () {// ...
};class Foo {constructor () {// ...}
}var foo = {bar () {// ...}
};var foo = async () => 1

此规则的正确代码示例包含以下"never"选项:

/*eslint space-before-function-paren: ["error", "never"]*/
/*eslint-env es6*/function foo() {// ...
}var bar = function() {// ...
};var bar = function foo() {// ...
};class Foo {constructor() {// ...}
}var foo = {bar() {// ...}
};var foo = async() => 1

{"anonymous": "always", "named": "never", "asyncArrow": "always"}

此规则的错误代码示例包含以下{"anonymous": "always", "named": "never", "asyncArrow": "always"}选项:

/*eslint space-before-function-paren: ["error", {"anonymous": "always", "named": "never", "asyncArrow": "always"}]*/
/*eslint-env es6*/function foo () {// ...
}var bar = function() {// ...
};class Foo {constructor () {// ...}
}var foo = {bar () {// ...}
};var foo = async(a) => await a

此规则的正确代码示例包含以下{"anonymous": "always", "named": "never", "asyncArrow": "always"}选项:

/*eslint space-before-function-paren: ["error", {"anonymous": "always", "named": "never", "asyncArrow": "always"}]*/
/*eslint-env es6*/function foo() {// ...
}var bar = function () {// ...
};class Foo {constructor() {// ...}
}var foo = {bar() {// ...}
};var foo = async (a) => await a

{"anonymous": "never", "named": "always"}

此规则的错误代码示例包含以下{"anonymous": "never", "named": "always"}选项:

/*eslint space-before-function-paren: ["error", { "anonymous": "never", "named": "always" }]*/
/*eslint-env es6*/function foo() {// ...
}var bar = function () {// ...
};class Foo {constructor() {// ...}
}var foo = {bar() {// ...}
};

此规则的正确代码示例包含以下{"anonymous": "never", "named": "always"}选项:

/*eslint space-before-function-paren: ["error", { "anonymous": "never", "named": "always" }]*/
/*eslint-env es6*/function foo () {// ...
}var bar = function() {// ...
};class Foo {constructor () {// ...}
}var foo = {bar () {// ...}
};

{"anonymous": "ignore", "named": "always"}

此规则的错误代码示例包含以下{"anonymous": "ignore", "named": "always"}选项:

/*eslint space-before-function-paren: ["error", { "anonymous": "ignore", "named": "always" }]*/
/*eslint-env es6*/function foo() {// ...
}class Foo {constructor() {// ...}
}var foo = {bar() {// ...}
};

此规则的正确代码示例包含以下{"anonymous": "ignore", "named": "always"}选项:

/*eslint space-before-function-paren: ["error", { "anonymous": "ignore", "named": "always" }]*/
/*eslint-env es6*/var bar = function() {// ...
};var bar = function () {// ...
};function foo () {// ...
}class Foo {constructor () {// ...}
}var foo = {bar () {// ...}
};

何时不使用

如果在函数括号之前不关心间距的一致性,则可以关闭此规则。

相关规则

  • space-after-keywords
  • space-return-throw-case

版本

此规则在ESLint 0.18.0中引入。

 如果有问题,欢迎大家评论区讨论,文章对你有用,给正在学习前端的小陈点个赞吧~~~

这篇关于ESLint 中的“ space-before-function-paren ”相关报错及其解决方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/430734

相关文章

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

SpringSecurity显示用户账号已被锁定的原因及解决方案

《SpringSecurity显示用户账号已被锁定的原因及解决方案》SpringSecurity中用户账号被锁定问题源于UserDetails接口方法返回值错误,解决方案是修正isAccountNon... 目录SpringSecurity显示用户账号已被锁定的解决方案1.问题出现前的工作2.问题出现原因各

javax.net.ssl.SSLHandshakeException:异常原因及解决方案

《javax.net.ssl.SSLHandshakeException:异常原因及解决方案》javax.net.ssl.SSLHandshakeException是一个SSL握手异常,通常在建立SS... 目录报错原因在程序中绕过服务器的安全验证注意点最后多说一句报错原因一般出现这种问题是因为目标服务器

qt5cored.dll报错怎么解决? 电脑qt5cored.dll文件丢失修复技巧

《qt5cored.dll报错怎么解决?电脑qt5cored.dll文件丢失修复技巧》在进行软件安装或运行程序时,有时会遇到由于找不到qt5core.dll,无法继续执行代码,这个问题可能是由于该文... 遇到qt5cored.dll文件错误时,可能会导致基于 Qt 开发的应用程序无法正常运行或启动。这种错

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM

CSS3中的字体及相关属性详解

《CSS3中的字体及相关属性详解》:本文主要介绍了CSS3中的字体及相关属性,详细内容请阅读本文,希望能对你有所帮助... 字体网页字体的三个来源:用户机器上安装的字体,放心使用。保存在第三方网站上的字体,例如Typekit和Google,可以link标签链接到你的页面上。保存在你自己Web服务器上的字

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

Java死锁问题解决方案及示例详解

《Java死锁问题解决方案及示例详解》死锁是指两个或多个线程因争夺资源而相互等待,导致所有线程都无法继续执行的一种状态,本文给大家详细介绍了Java死锁问题解决方案详解及实践样例,需要的朋友可以参考下... 目录1、简述死锁的四个必要条件:2、死锁示例代码3、如何检测死锁?3.1 使用 jstack3.2

html 滚动条滚动过快会留下边框线的解决方案

《html滚动条滚动过快会留下边框线的解决方案》:本文主要介绍了html滚动条滚动过快会留下边框线的解决方案,解决方法很简单,详细内容请阅读本文,希望能对你有所帮助... 滚动条滚动过快时,会留下边框线但其实大部分时候是这样的,没有多出边框线的滚动条滚动过快时留下边框线的问题通常与滚动条样式和滚动行