본문 바로가기

FrontEnd/React

[FrontEnd] Eject ,SASS, CSS Modules

Eject

이 도구의 개발자는 그렇게 사용자들을 ‘그 환경에 가둬놓으면’ 안되는걸 알기 때문에 이를 대비하여 eject라는 기능을 만들어줬습니다.

이 기능의 역할은 현재 프로젝트의 모든 설정 / 스크립트를 여러분의 프로젝트로 옮겨줍니다. eject를 하고나서는, 여러분 마음대로 커스터마이징이 가능합니다.


솔직히 머하는 건지 아직 잘 모르겠다.


{
"name": "frontend",
"version": "0.1.0",
"private": true,
"dependencies": {
"@babel/core": "7.1.0",
"@svgr/webpack": "2.4.1",
"babel-core": "7.0.0-bridge.0",
"babel-eslint": "9.0.0",
"babel-jest": "23.6.0",
"babel-loader": "8.0.4",
"babel-plugin-named-asset-import": "^0.2.3",
"babel-preset-react-app": "^6.1.0",
"bfj": "6.1.1",
"case-sensitive-paths-webpack-plugin": "2.1.2",
"chalk": "2.4.1",
"css-loader": "1.0.0",
"dotenv": "6.0.0",
"dotenv-expand": "4.2.0",
"eslint": "5.6.0",
"eslint-config-react-app": "^3.0.5",
"eslint-loader": "2.1.1",
"eslint-plugin-flowtype": "2.50.1",
"eslint-plugin-import": "2.14.0",
"eslint-plugin-jsx-a11y": "6.1.2",
"eslint-plugin-react": "7.11.1",
"file-loader": "2.0.0",
"fork-ts-checker-webpack-plugin-alt": "0.4.14",
"fs-extra": "7.0.0",
"html-webpack-plugin": "4.0.0-alpha.2",
"identity-obj-proxy": "3.0.0",
"jest": "23.6.0",
"jest-pnp-resolver": "1.0.1",
"jest-resolve": "23.6.0",
"mini-css-extract-plugin": "0.4.3",
"node-sass": "^4.10.0",
"optimize-css-assets-webpack-plugin": "5.0.1",
"pnp-webpack-plugin": "1.1.0",
"postcss-flexbugs-fixes": "4.1.0",
"postcss-loader": "3.0.0",
"postcss-preset-env": "6.0.6",
"postcss-safe-parser": "4.0.1",
"react": "^16.6.1",
"react-app-polyfill": "^0.1.3",
"react-dev-utils": "^6.1.1",
"react-dom": "^16.6.1",
"resolve": "1.8.1",
"sass-loader": "7.1.0",
"style-loader": "0.23.0",
"terser-webpack-plugin": "1.1.0",
"url-loader": "1.1.1",
"webpack": "4.19.1",
"webpack-dev-server": "3.1.9",
"webpack-manifest-plugin": "2.0.4",
"workbox-webpack-plugin": "3.6.3"
....


다만 pakage.json에 이런것들이 우수수수수 생기는데


아마 create-react-app에서 같이 설치된 도구들을

패키지에 입력하게 되어 우리가 입맛대로 수정할 수 있게 만들어 주게 하는 것 같다.

SASS & CSS MODULES

이번에 create-react-app이 버전 업그레이드가 되면서

CRA version2부터는 SASS CSS Module을 따로 셋팅 할 필요 없이 설치해서 사용하면 된다.


yarn add node-sass


SASS는 CSS를 좀 더 스크립트 언어를 컴퓨터 언어로 만든 것이고

CSS Modules은 CSS의 클래스 명을 더 편하게 사용할 수 있도록 도와줌



요로코롬 파일 이름만 변경하면


$bg-color와 같이 변수 선언이 가능하다!


주의할 점은 클래스명에 -가 안된다는점 고로 여기선 __를 사용



보기와 같이 임포트 ㅏㅎ고


클래스명은 다음형식으로!



이렇게 하면 보기와 같이 남들이 소스코드로 훔쳐볼 수 없게 새로운 클래스 명이 정해질 뿐 아니라


만약 팀과 작업할 시에 class가 겹치는 경우가 없어진다!


만약 클래스를 추적하고 싶게 만들고 싶다면


localIdentName을 검색해보자!



'FrontEnd > React' 카테고리의 다른 글

Redux 정의 및 인스톨  (0) 2018.11.11
[FrontEnd] 백엔드 서버와 연결하기!  (0) 2018.11.10
[FrontEnd]React! install!!!!!!!!(InstagramClone)  (0) 2018.11.10
[React] movie_app//8. await  (0) 2018.10.04
[React] movie_app//7. AJAX  (0) 2018.10.01