Eslint参考手册
规则 | Rules
getter-return
get 语法将一个对象属性绑定到一个函数,该函数将在查找该属性时被调用。它首先在 ECMAScript 5 中引入:
var p = {
get name(){
return "nicholas";
}
};
Object.defineProperty(p, "age", {
get: function (){
return 17;
}
});
请注意,每个getter
预期都会返回一个值。
规则细节
该规则强制在属性获取器中存在返回语句。
此规则的错误代码示例:
/*eslint getter-return: "error"*/
p = {
get name(){
// no returns.
}
};
Object.defineProperty(p, "age", {
get: function (){
// no returns.
}
});
class P{
get name(){
// no returns.
}
}
此规则的正确代码示例:
/*eslint getter-return: "error"*/
p = {
get name(){
return "nicholas";
}
};
Object.defineProperty(p, "age", {
get: function (){
return 18;
}
});
class P{
get name(){
return "nicholas";
}
}
选项
该规则有一个对象选项:
-
"allowImplicit": false
(默认)不允许隐式返回未定义的返回; 声明。
选项的正确代码示例{ "allowImplicit": true }
:
/*eslint getter-return: ["error", { allowImplicit: true }]*/
p = {
get name(){
return; // return undefined implicitly.
}
};
何时不使用它
如果您的项目不使用 ES5 属性获取器,则不需要此规则。
进一步阅读
- MDN: Functions getter
- Understanding ES6: Accessor Properties
版本
这条规则是在 ESLint 4.2.0 中引入的。
资源
- Rule source
- Documentation source
规则 | Rules相关
ESLint 是一个代码规范和错误检查工具,有以下几个特性。所有东西都是可以插拔的。你可以调用任意的 rule api 或者 formatter api 去打包或者定义 rule or formatter。任意的 rule 都是独立的。没有特定的 coding style,你可以自己配置。
主页 | https://eslint.org/ |
源码 | https://github.com/eslint/eslint |
发布版本 | 4.12.0 |