Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dev-jeromebaek/react-starter-kit
⭐️ React starter kit format with JS
https://github.com/dev-jeromebaek/react-starter-kit
eslint prettier react reactjs styled-components stylelint
Last synced: about 5 hours ago
JSON representation
⭐️ React starter kit format with JS
- Host: GitHub
- URL: https://github.com/dev-jeromebaek/react-starter-kit
- Owner: Dev-Jeromebaek
- License: mit
- Created: 2019-11-13T06:51:22.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-04-03T21:08:06.000Z (over 1 year ago)
- Last Synced: 2024-04-14T06:46:02.783Z (7 months ago)
- Topics: eslint, prettier, react, reactjs, styled-components, stylelint
- Language: JavaScript
- Homepage:
- Size: 142 KB
- Stars: 2
- Watchers: 2
- Forks: 1
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# react-starter-js
## 목차
1. [프로젝트 생성](#1-프로젝트-생성)
2. [lint 설치](#2-lint-설치)
3. [eslint 설정](#3-eslint-설정)
4. [prettier 설정](#4-prettier-설정)
5. [stylelint 설정](#5-stylelint-설정)
6. [프로젝트 기본경로 설정](#6-프로젝트-기본경로-설정)
7. [styled-components](#7-styled-components)
## 1. 프로젝트 생성
```shell
$ npx create-react-app [프로젝트명]
```## 2. lint 설치
- `eslint`
- `prettier`
- `stylelint````shell
$ yarn add --dev eslint prettier stylelint
```## 3. eslint 설정
```shell
$ npx eslint --init
``````shell
? How would you like to use ESLint? To check syntax, find problems, and enforce code style
? What type of modules does your project use? JavaScript modules (import/export)
? Which framework does your project use? React
? Does your project use TypeScript? No
? Where does your code run? Browser
? How would you like to define a style for your project? Use a popular style guide
? Which style guide do you want to follow? Airbnb (https://github.com/airbnb/javascript)
? What format do you want your config file to be in? JSON
Checking peerDependencies of eslint-config-airbnb@latest
The config that you've selected requires the following dependencies:eslint-plugin-react@^7.14.3 eslint-config-airbnb@latest eslint@^5.16.0 || ^6.1.0 eslint-plugin-import@^2.18.2 eslint-plugin-jsx-a11y@^6.2.3 eslint-plugin-react-hooks@^1.7.0
? Would you like to install them now with npm? Yes
```### 3.1 추가 패키지 설치
- `babel-eslint`
- `eslint-config-prettier`
- `eslint-plugin-testing-library````shell
$ yarn add --dev babel-eslint eslint-config-prettier eslint-plugin-testing-library
```### 3.2 parser, extends, rules 추가
- `.eslintrc.json`
```json
// .eslintrc.json{
"parser": "babel-eslint",
"env": {
"browser": true,
"es6": true,
"commonjs": true,
"node": true,
"jest": true
},
"extends": [
"airbnb",
"prettier",
"plugin:react/recommended",
"plugin:testing-library/recommended",
"plugin:testing-library/react"
],
"globals": {
"Atomics": "readonly",
"SharedArrayBuffer": "readonly"
},
"parserOptions": {
"ecmaFeatures": {
"jsx": true
},
"ecmaVersion": 2018,
"sourceType": "module"
},
"plugins": ["react", "react-hooks", "jsx-a11y", "import"],
"rules": {
// https://eslint.org/docs/rules/require-jsdoc
"require-jsdoc": [
0,
{
"require": {
"FunctionDeclaration": true,
"MethodDefinition": true,
"ClassDeclaration": true,
"ArrowFunctionExpression": false,
"FunctionExpression": false
}
}
],
// https://eslint.org/docs/rules/valid-jsdoc
"valid-jsdoc": [
1,
{
"requireReturn": false
}
],
"no-unused-vars": 1,
// individual
"react/jsx-filename-extension": 0,
"react/jsx-one-expression-per-line": 0,// testing-library --- https://github.com/Belco90/eslint-plugin-testing-library
"testing-library/await-async-query": "error",
"testing-library/await-fire-event": "warn",
"testing-library/no-await-sync-query": "error",
"testing-library/no-debug": "warn",
"testing-library/no-dom-import": "warn",
"testing-library/prefer-expect-query-by": "warn",
"testing-library/prefer-explicit-assert": "warn"
}
}
```### 3.3 script 추가
- `package.json`
```json
"scripts": {
// start, build, test, eject ...
"format:es": "eslint src"
}
```## 4. prettier 설정
### 4.1 vscode 설정
- `settings` 열기
`cmd+shift+p` => open settings(JSON)
- eslint, stylelint 설정 추가
- `"prettier-eslintIntegration": true,`
- ` "prettier-stylelintIntegration": true,````json
// settings.json{
// ...
"prettier-eslintIntegration": true,
"prettier-stylelintIntegration": true
}
```### 4.2 prettierrc 파일 생성 및 설정
- `.prettierrc.json`
```json
// .prettierrc.json{
"singleQuote": true,
"trailingComma": "all",
"printWidth": 80,
"arrowParens": "avoid",
"tabWidth": 2,
"rules": {
"sort-imports": 2
},
"proseWrap": "preserve",
"react/jsx-wrap-multilines": [
"error",
{
"declaration": false,
"assignment": false
}
]
}
```### 4.3 script 추가
- `package.json`
```json
"scripts": {
// start, build, test, eject ...
"format:pre-write": "prettier --write \"src/**/*\""
}
```## 5. stylelint 설정
### 5.1 추가 패키지 설치
- `stylelint-config-airbnb`
- `stylelint-order`
- `stylelint-scss````shell
$ yarn add --dev stylelint-config-airbnb stylelint-order stylelint-scss
```### 5.2 stylelintrc 파일 생성 및 설정
- `.stylelintrc.json`
```json
// .stylelintrc.json{
"extends": ["stylelint-config-airbnb"],
"rules": {
"rule-empty-line-before": "always"
}
}
```### 5.3 script 추가
- `package.json`
```json
"scripts": {
// start, build, test, eject ...
"format:style-fix": "stylelint --fix \"src/**/*\""
}
```## 6. 프로젝트 기본경로 설정
- jsconfig.json 파일 생성 및 수정
```json
// jsconfig.json{
"compilerOptions": {
"baseUrl": ".",
"paths": {
"*": ["*", "src/*"]
}
}
}
```## 7. styled-components
### 7.1 패키지 설치
- `styled-components`
```shell
$ yarn add styled-components
```- example
`
```javascript
// Create a Title component that'll render antag with some styles
const Title = styled.h1`
font-size: 1.5em;
text-align: center;
color: palevioletred;
`;// Create a Wrapper component that'll render a tag with some styles
const Wrapper = styled.section`
padding: 4em;
background: papayawhip;
`;// Use Title and Wrapper like any other React component – except they're styled!
render(
Hello World!
);
````
### 7.2 stylelint에 styled-components 추가
- 패키지 설치
- `stylelint-processor-styled-components`
- `stylelint-config-styled-components`
- `stylelint-config-recommended````shell
$ yarn add --dev stylelint-processor-styled-components stylelint-config-styled-components stylelint-config-recommended
```- .stylelintrc 수정
```json
// .stylelintrc.json{
"processors": ["stylelint-processor-styled-components"],
"extends": [
"stylelint-config-airbnb",
"stylelint-config-recommended",
"stylelint-config-styled-components"
],
"rules": {
"rule-empty-line-before": "always"
}
}
```