CRA + React Leaflet: failed to compile
Asked Answered
G

1

14

I've just started a brand new project using create-react-app and set up react-leaflet as their documentation recommends here.

I am trying to use this example to check if it's all working good but then I'm receiving the following error:

./node_modules/@react-leaflet/core/esm/path.js 10:41
Module parse failed: Unexpected token (10:41)
File was processed with these loaders:
 * ./node_modules/react-scripts/node_modules/babel-loader/lib/index.js
You may need an additional loader to handle the result of these loaders.
|   useEffect(function updatePathOptions() {
|     if (props.pathOptions !== optionsRef.current) {
>       const options = props.pathOptions ?? {};
|       element.instance.setStyle(options);
|       optionsRef.current = options;

Looks like react-scripts can't handle react-leaflet files. Can someone helps me to understand why it's happening and how do I fix it ?

Guilbert answered 15/5, 2021 at 23:5 Comment(2)
A
16

After reading about it on all blogs , I have concluded that : It's because of the new version of the react-leaflet. I faced the same problem and here's how I got rid of the error:

Open your package.json file

 "browserslist": {
 "production": [
  ">0.2%",
  "not dead",
  "not op_mini all"
],
"development": [
  "last 1 chrome version",
  "last 1 firefox version",
  "last 1 safari version"
]
},

Replace it with following lines :

"browserslist": [
">0.2%",
"not dead",
"not op_mini all"
],
  • Now Delete node_modeules/.cache folder

  • npm install

  • npm start

Another method is to just add these lines in your package.json file:

"react-leaflet": ">=3.1.0 <3.2.0 || ^3.2.1",
"@react-leaflet/core": ">=1.0.0 <1.1.0 || ^1.1.1"
Anaclinal answered 27/5, 2021 at 9:48 Comment(5)
The second method worked for me (didn't try the first one). Make sure to erase your cache folder as stated, but I would say also package-lock.jsonIotacism
Here is a video that has the same fix if you’re a visual learner. youtu.be/tFqj-JKYr4MYokoyama
The video is what I needed, thanks @YokoyamaWorried
Happy it helped.Yokoyama
thanks, the video helped me too!Scavenger

© 2022 - 2024 — McMap. All rights reserved.