Search
 
SCRIPT & CODE EXAMPLE
 

JAVASCRIPT

Vs Code Setup for Reactjs Project

Linting Setup

In order to lint and format your React project automatically according to popular airbnb style guide, I recommend you to follow the instructions below.
Install Dev Dependencies

yarn add -D prettier
yarn add -D babel-eslint
npx install-peerdeps --dev eslint-config-airbnb
yarn add -D eslint-config-prettier eslint-plugin-prettier

or You can also add a new script in the scripts section like below to install everything with a single command:

scripts: {
    "lint": "yarn add -D prettier && yarn add -D babel-eslint && npx install-peerdeps --dev eslint-config-airbnb && yarn add -D eslint-config-prettier eslint-plugin-prettier"
}

and then simply run the below command in the terminal -

yarn lint #or 'npm run lint'

Create Linting Configuration file manually

Create a .eslintrc file in the project root and enter the below contents:
{
  "extends": [
    "airbnb",
    "airbnb/hooks",
    "eslint:recommended",
    "prettier",
    "plugin:jsx-a11y/recommended"
  ],
  "parser": "babel-eslint",
  "parserOptions": {
    "ecmaVersion": 8
  },
  "env": {
    "browser": true,
    "node": true,
    "es6": true,
    "jest": true
  },
  "rules": {
    "react/react-in-jsx-scope": 0,
    "react-hooks/rules-of-hooks": "error",
    "no-console": 0,
    "react/state-in-constructor": 0,
    "indent": 0,
    "linebreak-style": 0,
    "react/prop-types": 0,
    "jsx-a11y/click-events-have-key-events": 0,
    "react/jsx-filename-extension": [
      1,
      {
        "extensions": [".js", ".jsx"]
      }
    ],
    "prettier/prettier": [
      "error",
      {
        "trailingComma": "es5",
        "singleQuote": true,
        "printWidth": 100,
        "tabWidth": 4,
        "semi": true,
        "endOfLine": "auto"
      }
    ]
  },
  "plugins": ["prettier", "react", "react-hooks"]
}


    e the below json in the newly created settings.json file and save the file.

{
  // Theme
  "workbench.colorTheme": "Dracula",

  // config related to code formatting
  "editor.defaultFormatter": "esbenp.prettier-vscode",
  "editor.formatOnSave": true,
  "[javascript]": {
    "editor.formatOnSave": false,
    "editor.defaultFormatter": null
  },
  "[javascriptreact]": {
    "editor.formatOnSave": false,
    "editor.defaultFormatter": null
  },
  "javascript.validate.enable": false, //disable all built-in syntax checking
  "editor.codeActionsOnSave": {
    "source.fixAll.eslint": true,
    "source.fixAll.tslint": true,
    "source.organizeImports": true
  },
  "eslint.alwaysShowStatus": true,
  // emmet
  "emmet.triggerExpansionOnTab": true,
  "emmet.includeLanguages": {
    "javascript": "javascriptreact"
  }
}

If you followed all previous steps, the theme should change and your editor should be ready.
Comment

PREVIOUS NEXT
Code Example
Javascript :: array and array compare 
Javascript :: mongoose id validator 
Javascript :: history of react js 
Javascript :: how to get country code in react native 
Javascript :: var function js 
Javascript :: what are the comparison operators in javascript 
Javascript :: copy folder in nodejs 
Javascript :: css defer async 
Javascript :: how to convert json to object 
Javascript :: return statement in javascript 
Javascript :: javascript css 
Javascript :: console.group in javascript 
Javascript :: javascript canvas load image 
Javascript :: material ui table row height 
Javascript :: javascript save multiple images to server 
Javascript :: simple website with html css and javascript 
Javascript :: javascript array looping 
Javascript :: discord.js give role command 
Javascript :: react validate 
Javascript :: trigger jquery autocomplete on click 
Javascript :: como ordenar um array em ordem crescente javascript 
Javascript :: math question 
Javascript :: dual array javascript 
Javascript :: node js package nodemon error 
Javascript :: how to add multiple videos in html5 with javascript 
Javascript :: patterns in javascript using for loop 
Javascript :: comment dire le nombre de ligne html en cliquamt sur un boutton javascript 
Python :: python request remove warning 
Python :: get wd in python 
Python :: sort dataframe by column 
ADD CONTENT
Topic
Content
Source link
Name
7+5 =