Today we are going to learn how we can set up ESLint for a project that uses React and React Native with JavaScript or TypeScript.
data:image/s3,"s3://crabby-images/31d2a/31d2adce2b9a63c3bfc711e665b8fcce2881910f" alt=""
This will allow us to recognize errors that appear in our code and configure the type of error we want.
First of all, we need to install ESLint:
npm install eslint --global
Once installed, we install it in our project.
npm install --save-dev eslint
And now let’s configure it:
eslint --init
It will ask us what we are going to use ESLint for:
data:image/s3,"s3://crabby-images/3bf3c/3bf3c60153e01d4f6a743ca7168fc72919b4e5f7" alt=""
In my case, I select the default option “To check syntax and find problems”.
Now select JavaScript modules:
data:image/s3,"s3://crabby-images/a6666/a6666df3c54de2523b4c0f02d009ef9bb4fae9ed" alt=""
The framework type in this case is React:
data:image/s3,"s3://crabby-images/dd095/dd09586e69efa53940c9b72ca08dc58102d5c34e" alt=""
If we are not using TypeScript, select No.
data:image/s3,"s3://crabby-images/53f77/53f77a3f02e642dff744b214e2a01203cf6b8f6e" alt=""
In my case, I run with Node, since I use React Native, then we select Node
data:image/s3,"s3://crabby-images/3c1d9/3c1d97c39e0a39fe9c756503206c9f95ae91ef1a" alt=""
The configuration format, we can choose whichever we want, in my case JavaScript.
data:image/s3,"s3://crabby-images/b95be/b95beb0e17202d8121e0335efbda00578ad1b183" alt=""
It will ask us if we want to install it and we select Yes. And using NPM in my case.
Once installed, it will have created a file called .eslintrc.js
I recommend installing the VSCode plugin ESLint.
data:image/s3,"s3://crabby-images/53a58/53a580de1e28a4363016226eaec7e2232f664237" alt=""
To have ESLint tell you what to import when it finds an import error, you can use the eslint-plugin-import
plugin. This plugin provides a number of rules related to imports in JavaScript, including import error detection.
npm install eslint-plugin-import --save-dev
And we can add it in the .eslintrc.js file
"plugins": ["import"], "rules": { "import/no-unresolved": "error" }
data:image/s3,"s3://crabby-images/dcda1/dcda1869d3b0ea466fe645d8fc18f277ea25d855" alt=""