ESLint
Learn how to integrate ESLint to your project
1. Add the base dependencies for ESLint to work with TypeScript
yarn add -D eslint @typescript-eslint/parser @typescript-eslint/eslint-plugin
2. Install eslint-config-airbnb
(with React support)
eslint-config-airbnb
(with React support)replace with
eslint-config-airbnb-typescript
if using typescript
yarn add -D eslint-config-airbnb eslint-plugin-react eslint-plugin-react-hooks eslint-plugin-jsx-a11y eslint-plugin-import
3. Initialize the ESLint
yarn eslint --init
React Version (JS)
.eslintrc.js
module.exports = {
env: {
browser: true,
es2021: true,
},
extends: [
'plugin:import/errors',
'plugin:import/warnings',
'plugin:jsx-a11y/recommended',
'plugin:react/recommended',
'plugin:react-hooks/recommended',
'airbnb',
],
parserOptions: {
ecmaFeatures: {
jsx: true,
},
ecmaVersion: 12,
sourceType: 'module',
},
plugins: ['react'],
rules: {
'no-console': 'off',
'react/prop-types': [2, { skipUndeclared: true }],
'react/jsx-props-no-spreading': 'off',
'react/jsx-filename-extension': [1, { extensions: ['.js', '.jsx'] }],
},
};
Next.js Version (TS)
.eslintrc.js
module.exports = {
env: {
browser: true,
es2021: true,
node: true,
},
extends: [
'plugin:import/errors',
'plugin:import/warnings',
'plugin:jsx-a11y/recommended',
'plugin:react/recommended',
'plugin:react-hooks/recommended',
'airbnb-typescript',
],
parser: '@typescript-eslint/parser',
parserOptions: {
ecmaFeatures: {
jsx: true,
},
ecmaVersion: 12,
sourceType: 'module',
project: 'tsconfig.json',
},
plugins: [
'react',
'@typescript-eslint',
],
rules: {
'no-console': 'off',
'react/react-in-jsx-scope': 'off',
'react/require-default-props': 'off',
'react/jsx-props-no-spreading': 'off',
},
ignorePatterns: ['.eslintrc.js'],
};
React Native Version (Legacy)
.eslintrc.js
module.exports = {
env: {
es2021: true,
node: true,
jest: true,
},
extends: [
'@react-native-community',
'plugin:import/errors',
'plugin:import/warnings',
'plugin:jsx-a11y/recommended',
'plugin:react/recommended',
'plugin:react-hooks/recommended',
'airbnb-typescript',
'airbnb/hooks',
'plugin:@typescript-eslint/recommended',
],
parser: '@typescript-eslint/parser',
parserOptions: {
ecmaFeatures: {
jsx: true,
},
ecmaVersion: 12,
sourceType: 'module',
project: 'tsconfig.json',
},
plugins: ['react', '@typescript-eslint'],
rules: {
'no-console': 'off',
'react/prop-types': ['warn', { skipUndeclared: true }],
'react-native/no-inline-styles': 'off',
'@typescript-eslint/no-explicit-any': 'off',
},
ignorePatterns: ['.eslintrc.js', 'babel.config.js', 'metro.config.js'],
};
Nest.js Version (TS)
.eslintrc.js
module.exports = {
parser: '@typescript-eslint/parser',
parserOptions: {
project: 'tsconfig.json',
sourceType: 'module',
},
plugins: ['@typescript-eslint/eslint-plugin'],
extends: [
'plugin:@typescript-eslint/eslint-recommended',
'plugin:@typescript-eslint/recommended',
],
root: true,
env: {
node: true,
jest: true,
},
rules: {
'@typescript-eslint/interface-name-prefix': 'off',
'@typescript-eslint/explicit-function-return-type': 'off',
'@typescript-eslint/no-explicit-any': 'off',
'@typescript-eslint/no-unused-vars': ['warn', { argsIgnorePattern: '^type$' }],
},
ignorePatterns: ['.eslintrc.js', '/src/config/ormconfig.js'],
};
Optional ???
tsconfig.json
{
"include": [
"next-env.d.ts",
"**/*.js",
"**/*.jsx",
"**/*.ts",
"**/*.tsx"
]
}
package.json
"scripts": {
...,
"lint": "eslint \"src/**/*.{js,jsx,ts,tsx}\" --fix"
},
Last updated
Was this helpful?