🌱SeSAC x CodingOn 웹 취업 부트캠프 21

[새싹/코딩온] 풀스택 웹 개발자 취업 부트캠프 12주차 (2): React Hooks, Router

Hooks- 함수형 컴포넌트에서 상태 관리와 생명주기 기능을 사용할 수 있게 해주는 함수.- Hook은 React의 함수형 컴포넌트 내에서만 사용 가능.- custom Hook 이름은 "use"로 시작하는 것을 권장.💻 주요 Hook 종류1. useState: 컴포넌트에서 상태를 관리할 수  있게 해준다.2. useEffect: 컴포넌트의 랜더링 이후에 특정 작업을 실행할 수 있게 해준다. useEffect(() => { console.log("location이 변경될 때 마다 실행됩니다. ✊🏻"); }, [location]);3. useMemo: 계산 비용이 높은 연산의 결과를 메모이제이션하여 성능을 최적화 한다. // [useMemo 사용!] // 특정 값이 변경되었을 때만 함수가 호출..

[새싹/코딩온] 풀스택 웹 개발자 취업 부트캠프 12주차 (1): React style

Style 적용💻 일반 CSS- inline style 적용하기export default function BasicCSS() { // object 따로 선언 const childDiv = { backgroundColor: "pink", width: "100px", height: "100px", textAlign: "center", lineHeight: "100px", }; return ( 스타일 적용 방법 인라인 스타일 CSS 파일 만들어서 import .module.css 파일 만들어서 import styled-components 라이브러리 사용(설치 필요) SAAS 사용 (설치..

[새싹/코딩온] 풀스택 웹 개발자 취업 부트캠프 11주차 (2): React Props & State, Event Handling, map(), filter(), Life Cycle

Props & State💻 Props (Properties)- 부모 컴포넌트에서 자식 컴포넌트로 데이터를 전달하는 방법 (상위➡️하위 만 가능!)- 여러 번 쓰이는 컴포넌트에서 내부 데이터만 다르게 사용하고 싶을 때 사용- 컴포넌트끼리 값을 전달하는 수단// Class형 propsimport { Component } from "react";// props는 반드시 객체이다.class ClassProps extends Component { render() { const divStyle = { color: this.props.color, }; return ( hi, {this.props.name} 별명: {this.props...

[새싹/코딩온] 풀스택 웹 개발자 취업 부트캠프 11주차 (1): React

ReactFacebook에서 개발한 사용자 인터페이스(UI) 구축을 위한 Javascript 라이브러리이다.🖥️ 특징1️⃣ Data Flow- 단방향 데이터 흐름을 채택하고 있다. 데이터는 부모 컴포넌트에서 자식 컴포넌트로 단방향 전달된다.2️⃣ Component 기반 구조- 어플리케이션의 UI를 독립적이고 재사용 가능한 조각으로 나누어 구성한다. - 코드의 재사용성과 유지보수성이 향상된다.3️⃣ Virtual DOM1) 상태 변경: 컴포넌트의 상태가 변경되면 React는 새로운 Virtual DOM 트리를 생성한다.2) 비교: 새로 생성된 Virtual DOM과 이전 Virtual DOM을 비교하여 변경된 부분을 파악한다.3) 재조정: 변경된 부분만을 실제 DOM에 적용한다.4️⃣ Props and ..

[새싹/코딩온] 풀스택 웹 개발자 취업 부트캠프 10주차: 프로젝트 회고 (3)

🌊고민 풀장🌊1️⃣ index.ejs의 레이아웃 구조는 유지하되 디자인은 mypage.ejs랑 좀 더 통일성 있게 바꿨다.포인트 디자인(버튼)은 유지하되 input area랑 바탕색을 다시 정렬했다. 고민 듣기 버튼을 누르면 display= "none", display= "block"을 사용해서 페이지 이동 없이 타인의 고민이 랜덤으로 들어온다. 더보기document.addEventListener("DOMContentLoaded", function () { const refreshButton = document.querySelector(".refresh-button"); const contentArea = document.querySelector(".content-area"); const new..

[새싹/코딩온] 풀스택 웹 개발자 취업 부트캠프 9주차: 프로젝트 회고 (2)

🌊고민 풀장🌊1️⃣ 온도계의 위치가 고민이였다.이미지 자체를 왼쪽에 두자니 전체적으로 모양새가 깨지는 느낌이였다. 이미지 사이즈도 너무 큰건 알겠는데 얼마나 줄여야 할지 감도 안왔다. 생각하다가 사이즈를 확 줄여버리고 header밑에 넣었다. 존재감도 덜 하면서 보기 쉬운 위치를 찾은 것 같아 마음에 들었다. 2️⃣ 사이즈가 안 맞다 싶으면 header에 세로 스크롤바가 생겼다. 이 부분은 overflow: hidden으로 지정된 요소 밖을 벗어나는건 잘리게 해버렸다. .header-wrapper { width: 100%; border-bottom: 1px solid rgba(0, 0, 0, 0.1); margin-left: calc(-50vw + 50%); overflow: hidden;}...

[새싹/코딩온] 풀스택 웹 개발자 취업 부트캠프 8주차: 프로젝트 회고 (1)

🌊고민 풀장🌊 1️⃣ 첫 번째 프로젝트! 고민을 던지면 랜덤한 한 사용자에게 고민이 날아가고, 고민을 수신한 사용자는 답장을 보낸다. 답장을 본 사용자가 별점으로 답장이 만족스러웠는지 평가하면 평가를 받은 사용자의 온도가 변하도록 시스템을 짰다. 모든 사용자는 익명으로 고민을 쓰고 답장한다. 답장은 한 번만 보낼 수 있고 답장에 대한 답장은 불가능하다. 이미 답장을 받은 고민은 다시 메인 풀(답장이 되지 않은 고민들이 담겨있는)로 돌아가지 않는다! 2️⃣ 프로젝트 주제를 정하고 역할 배분을 하는 데 생각보다 시간이 걸렸다. 와이어프레임을 Figma로 짜는데, 이것저것 수정하다 보니 일주일이라는 시간도 부족하다고 생각했다.🫠

[새싹/코딩온] 풀스택 웹 개발자 취업 부트캠프 7주차 (2): JWT, 비밀번호 암호화

JWT💡OAuth란? (Open Authorization)사용자의 리소스에 대한 접근 권한을 안전하게 위임하기 위한 개방형 표준 프로토콜!사용자가 비밀번호를 제공하지 않고도 제3자 어플리케이션에 권한을 부여할 수 있다.주로 소셜 미디어 로그인이나 외부 서비스 연동에 사용된다.💡 JWT (Json Web Token)사용자 인증에 주로 사용되는 토큰 기반 인증 방식!JSON 형식의 정보를 안전하게 전송하기 위한 표준 규격Header, Payload, Signature 세 부분으로 구성된다.토큰 자체에 사용자 정보를 포함하고 있어 서버에서 별도의 세션 저장소가 필요 없다.주로 웹 어플리케이션에서 사용자 인증을 위해 사용.더보기// app.js// POST /loginapp.post("/login", (re..

[새싹/코딩온] 풀스택 웹 개발자 취업 부트캠프 7주차 (1): Cookie & Session

🍪Cookie🍪웹 브라우저(클라이언트)에 저장되는 키와 값이 들어있는 작은 데이터 파일클라이언트 측에 저장되므로 보안에 취약할 수 있다!이름, 값, 만료일, 경로 정보로 구성되어 있다.더보기 // 백엔드 쿠키 설정// cookie.jsconst express = require("express");const cookieParser = require("cookie-parser");const app = express();const PORT = 8080;// ver1. 암호화 되지 않은 쿠키// app.use(cookieParser());// ver2. 암호화된 쿠키// 실제로 암호화 쿠키를 사용한다면 비밀키도 .env로 관리하는 것이 좋다. 문자열은 아무거나 상관 없음app.use(cookieParse..

[새싹/코딩온] 풀스택 웹 개발자 취업 부트캠프 6주차 (2): 환경변수, Sequelize, Database 응용

환경변수운영체제나 소프트웨어에서 참조하는 변수로, 프로그램 동작에 영향을 주는 값들을 저장한다.💻 dotenv .env 파일에 키=값 형식으로 환경변수를 정의보안에 민감한 정보를 코드에서 분리할 수 있다!보안상 중요한 정보를 포함하므로 .gitignore에 추가하여 버전 관리에서 제외해야 한다.SequelizeNode.js에서 사용하는 ORM(Object-Relational Mapping)라이브러리개발자가 SQL 쿼리를 직접 작성하지 않고도 Javascript 객체를 통해 데이터베이스와 상호 작용할 수 있다!💻 모델 정의Sequelize.define(param1, param2, param3);// param1: 모델(테이블) 이름 설정// param2: 컬럼 정의// param3: 모델 옵션 정의💻..