D.evelop/React
[React]CRA 세팅 Failed to compile 에러 (eslint, prettier)
Danne
2021. 11. 17. 16:28
MEGAFOX 팀 프로젝트 - 초기세팅 을 참고하여 개인 포트폴리오를 위한 새로운 CRA 프로젝트를 생성했다.
그 짧은 시간동안 react-router의 업데이트(v5 → v6)가 있어서 이번 프로젝트에 적용해보기로 했다.
그렇게 세팅을 하고 npm start
!!
prettier 플러그인 로드에 실패했다. eslint-plugin-prettier 모듈을 찾을 수 없다구.
.eslintrc에 사용하겠다고 적어두었는데 찾을 수가 없네?
CRA에는 eslint가 내장 되어있지만, 추가설정을 위한 package는 따로 설치해야한다.
npm install -D prettier eslint-config-prettier eslint-plugin-prettier
성공과 동시에
네! 다음 Error😃
Failed to compile
Error while loading rule 'prettier/prettier': context.getPhysicalFilename is not a function
Occurred while linting /Users/dan/Desktop/dan_dev/dand_portfolio/src/index.js`
그래도 우린 구면이잖아? MEGAFOX CRA 초기세팅 에러
하지만 키워드와 명령어만 알았지 좀 더 깊게는 생각 안하고 지나갔었나보다.
해결책이 바로바로 안나온다.
또 다시!
패키지 간의 종속성을 찾아서
참고 : Charles Stover - Resolving Prettier + React
위 블로그를 참고하여 일부 의역했습니다.
React 프로젝트는 빌드 시 react-script를 사용한다.
...
yarn.lock에서 react-scripts는 eslint@^7.11.0을 요구하는 것을 볼 수 있다.
그러나 종속성을 lock했으므로 마지막으로 설치된 버전을 사용한다.
당신은 두 개의 설치 파일을 확인 할 수 있다.
package-lock.json 확인
...
"eslint": {
"version": "7.20.0",
...
"eslint-plugin-prettier": {
"version": "4.0.0",
...
eslint@^7.20.0
eslint-plugin-prettier@^4.0.0
yarn.lock 확인
react-script는 eslint@^7.11.0에 의존
eslint명령으로 호출할 때, package.json에서 설치된 버전을 사용합니다 .
그러나 react-scripts가 eslint를 호출 할 때, 가장 react-scripts 마지막에 성공적으로 설치된 react-scripts와 함께 사용됩니다. - "locked in"상태인.
이 버전은 Prettier plugin과 호환되지 않으므로 실패됩니다.
...
문제 해결을 위해여 react-scripts의 종속성을 강제로 업데이트 할 수 있다.
Yarn은 ESLint를 업그레이드할 뿐만 아니라 모든 종속성에 대한 ESLint도 업그레이드합니다.
따라서 이제 최신 버전의 ESLint를 사용하고 성공합니다.
yarn install
yarn upgrade -R eslint
다시 npm start !!
🥲
그래도 이건 package 버전 문제는 아니니까..
오류 해결!
반응형