오늘은 지난 시간에 이어 간단한 일기장 프로젝트의 추가 기능을 구현해보는 날이다 저번 시간에는 일기장의 틀만 구성했다면 오늘은 추가, 삭제, 수정 기능을 구현하고 Lifecycle을 제어하는 방법에 대해서 배워볼 것이다 CRUD는 모든 서비스에서 가장 기본적인 기능이기 때문에 오늘 강의를 잘 듣고 확실하게 배워두어야겠다 오늘도 그럼 화이팅! # React에서 배열 사용하기 2 - 데이터 추가 배열을 이용한 React의 List에 아이템을 동적으로 추가해보자 또한 React처럼 생각하는 방법을 배워보자 리액트로 프로젝트를 개발할 때 코드를 작성하는 것도 중요하지만 그 전에 컴포넌트 트리에 대해서 생각해보아야 한다 App 컴포넌트를 부모 컴포넌트로 하여 DiaryEditor 컴포넌트와 DiaryList 컴포..
자바스크립트
이번주는 React를 사용해서 간단한 일기장 구현 프로젝트가 진행된다 일기장 기능에는 CRUD 가 전부 포함되어 있기 때문에 이번 간단한 프로젝트에서 확실하게 배우면 나중에 더 크고 복잡한 프로젝트를 할 때 도움이 될 수 있을 것이다 기본기를 탄탄하게 잡고 시작한다는 느낌으로 이번 강의도 열심히 듣고 따라하고 정리해보겠다 # 프로젝트 소개 간단한 일기장 프로젝트를 통해 React의 사용법을 배워보자 Point 1. 사용자 입력 및 배열 리스트 처리하기 Point 2. React Lifecycle과 API Point 3. React App 프로처럼 성능 최적화하기 with 도구 사용 Point 4. React 컴포넌트 트리에 전역 데이터 공급하기 # React 에서 사용자 입력 처리하기 npx create..
지난 시간에는 Node.js에 대해서 배우고 설치까지 해보았다 오늘부터는 본격적으로 React에 대해서 배워보는 시간이다 오늘은 React 가 무엇인지, 어떻게 리액트 파일을 생성하는지, 문법은 어떻게 되는지 등 React 에 대한 전반적인 기초 지식에 대한 강의가 진행된다 강의를 들으며 중요한 내용을 잘 정리하고 추가로 궁금한 부분을 메모해두어야겠다 오늘도 그럼 화이팅! # React # React를 왜 사용할까? 1. 중복되는 코드를 컴포넌트화 시켜 재사용할 수 있다 2. 선언형 프로그래밍이다 -> 바로 목적을 말한다 3. Virtual DOM # DOM이란? Document Object Model 의 약자 브라우저가 HTML을 해석해서 보여줄 때 HTML을 트리 형태로 변경한 것 Virtual DO..
오늘은 2월의 시작이다 2월의 시작을 맞이하여 오늘부터 리액트 강의가 시작된다 옛날에 직접 구매해서 봤던 강의와 동일한 내용이라 복습하는 차원에서 기초부터 보면서 다시 한번 리액트의 개념에 대해 정리하고 간단한 토이 프로젝트를 만들어보려고 한다 2월도 화이팅! # React 소개 # React 란? 지금은 Meta가 된 Facebook이 개발한 오픈소스로 자바스크립트의 UI 라이브러리이다 즉, 자바스크립트를 알아야지 리액트를 쓸 수 있다 # Node.js란? 자바스크립트는 어떻게 실행될까? 브라우저에 내장되어 있는 자바스크립트 엔진을 이용하여 실행된다 하지만 브라우저들은 서로 다른 엔진을 사용한다 아래는 각 브라우저 별로 사용하는 내장 엔진의 종류이다 크롬 브라우저가 가진 v8이 가장 대표적인 자바스크립..
오늘의 강의는 알고리즘 4문제를 해결하는 것이다 Level0 부터 Level2 까지 총 4문제를 해결하고 구현 방법을 간단히 정리하겠다 소스코드 및 더욱 구체적인 해결 방법은 알고리즘 카테고리에 따로 정리할 것이다 일단 익숙한 자바로 문제를 해결해보았다 자바스크립트로 코드를 변경해보고 그것도 따로 포스팅하도록 하겠다 모든 문제는 자바를 기준으로 정리하였다 # [Lv0] 문자 개수 세기 아스키 코드에 대해서 알면 쉽게 풀리는 문제이다 아스키 코드로 알파벳을 숫자로, 숫자를 알파벳으로 변환할 줄 알아야 한다 # [Lv0] 이어 붙인 수 자바를 기준으로 String을 int로, int를 String으로 변환하여 코드를 짜면 금방 풀 수 있는 문제이다 (자바스크립트는 어떨지 아직 모르겠다) # [Lv1] 크기가..
오늘은 고양이 사진 검색 사이트 해설의 마지막 강의인 추가 요구 사항 3가지를 해결하는 내용이다 마지막 강의에서는 엄청 중요한 기능은 아니지만 사용자 경험을 향상시킬 수 있는 추가적인 기능 구현에 대해 진행된다 이번 강의를 통해서 더 많은 것을 알아가야겠다 # 추가 요구 사항 해결 # 추가 요구 사항 1 1. 최근 검색어 input 창에 마우스 호버시에만 보이도록 하기 SearchInput 컴포넌트 내에 SearchInputSection 클래스를 생성한다 상단의 input과 최근 검색어 부분이 한 section 안에 위치되도록 한다 CSS 설정을 통해서 input 창에 마우스 hover 시에만 최근 검색어가 보이도록 설정한다 # SearchInputSection에 적용한 CSS .SearchInputSe..
지금까지 배운 고양이 사진 검색 사이트에 대한 내용을 바탕으로 모의 테스트를 진행하는 날이다 최종 모의 테스트, 과제 테스트로 총 두개의 테스트에 대한 후기를 작성해보고자 한다 # 테스트 후기 # 최종 모의 테스트 최종 모의테스트는 2시간 동안 두개의 필수 요구사항을 해결하는 문제였다 프로그래머스에서 출제한 모의 테스트이기 때문에 자세한 문제 내용이나 코드를 첨부할 수는 없을 듯하여 문제를 풀이하며 기억에 남는 것, 중요했던 것, 헷갈린 개념 등을 정리해보려고 한다 (혹시나 해서 테스트 결과 보기로 들어가서 확인해봤는데 코드가 바꼈네..?!) # 필수 과제 1 첫번째 필수 과제는 검색어를 자동 완성하는 것이다 input 창에 검색어를 누르기만 하면 바로 밑에 해당 검색어가 포함된 데이터들을 리스트 형식으..
# 미션 3 # api 요청 결과 리팩토링 및 async - await 도입 에러 처리할 때는 백엔드팀과 회의를 통해서 어떤 에러를 어떻게 처리할 것인지 조율해야 한다 이번 실습에서는 500 에러를 처리하는 방법에 대해서만 다루겠다 const REQUEST_ERROR = { 500: { msg: "요청 실패" }, }; //request에서 에러처리까지 한번에 가능 const request = async (url) => { try { //result의 값이 생길 때까지 아래 코드는 대기 const result = await fetch(url); if (result.status === 200) { return result.json(); } else { throw REQUEST_ERROR[result.sta..