nextjs를 설치하면 eslint가 정말 기본으로 설치로되어있기 때문에 기본 eslint 설치는 생략한다.
eslint 룰은 유명한 air-bnb를 사용한다.
yarn add -D eslint-plugin-react-hooks
yarn add -D eslint-plugin-import
yarn add -D prettier eslint-plugin-prettier eslint-config-prettier
yarn add -D eslint-config-airbnb
{
"env": {
"browser": true,
"es2021": true
},
"extends": [
"airbnb",
"prettier",
"plugin:jsx-a11y/recommended",
"eslint:recommended",
"plugin:react/recommended",
"plugin:@typescript-eslint/recommended",
"plugin:prettier/recommended",
"plugin:import/recommended"
],
"overrides": [],
"parser": "@typescript-eslint/parser",
"parserOptions": {
"ecmaVersion": "latest",
"sourceType": "module"
},
"plugins": [
"react",
"@typescript-eslint",
"prettier",
"import"
],
"rules": {
"import/extensions": [
"error",
"ignorePackages",
{
"js": "never",
"jsx": "never",
"ts": "never",
"tsx": "never",
"json": "never"
}
],
"react/jsx-filename-extension": [
2,
{
"extensions": [
".js",
".jsx",
".ts",
".tsx"
]
}
],
"prettier/prettier": [
"error",
{
"endOfLine": "auto"
}
],
"import/prefer-default-export": "off",
"react/react-in-jsx-scope": "off",
"import/no-extraneous-dependencies": [
"error",
{
"devDependencies": true
}
],
"react/jsx-props-no-spreading": [
"warn"
]
},
"settings": {
"import/resolver": {
"typescript": {},
"node": {
"extensions": [
".js",
".jsx",
".ts",
".tsx"
]
}
}
}
}
위의 eslint 설정파일을 작성하고 추가적으로 prettier를 설정한 후 사용한다.