React 실습 (39) 썸네일형 리스트형 [Next.js] 4장 - 코드 구성과 데이터 불러오기 (학습 중 메모 정리 - 나중에 할것) USER getaddrinfo ENOTFOUND api.rwnjs.com? ChatGPT "getaddrinfo ENOTFOUND api.rwnjs.com" 에러 메시지는 일반적으로 DNS(Domain Name System)에 의해 도메인 이름 "api.rwnjs.com"을 IP 주소로 변환할 수 없다는 것을 나타냅니다. 이는 네트워크 연결 문제, 올바르지 않은 DNS 서버 구성 또는 도메인 이름 자체의 문제로 인한 것일 수 있습니다. 이 문제를 해결하기 위해 다음과 같은 단계를 시도해 볼 수 있습니다: 인터넷 연결을 확인하고 안정적인 연결을 보장합니다. DNS 서버가 올바르게 구성되어 있는지 확인합니다. User Request URL: http://localhos.. 에디터 quill Events text-change Emitted when the contents of Quill have changed. Details of the change, representation of the editor contents before the change, along with the source of the change are provided. The source will be "user" if it originates from the users. For example: User types into the editor User formats text using the toolbar User uses a hotkey to undo User uses OS spelling correction Chang.. 리액트 커스텀 훅 만들기 Custom Hooks? 컴포넌트를 만들다 보면 반복되는 로직이 자주 발생된다. 따라서 custom hooks를 만들어서 반복되는 로직을 쉽게 재활용 할 수 있다. Custom Hooks는 "use"라는 단어로 시작한다. (ex: useFetch) useFetch 만들기 기존에 사용했던 fetch는 아래처럼 모든 component에 사용해야했다. const [sources, setSources] = useState([]); useEffect(() => { fetch('data/movieCarouselData.json', { method: 'GET', }) .then(res => res.json()) .then(data => { setSources(data); }); }, []); 하지만 custom ho.. [React] 자식이 부모에게 - 콜백 이용 + 알아야 할 것 함수를 props로 사용하여 자식 컴포넌트가 부모와 통신이 가능하도록 하는 방법 + 실습 Player 컴포넌트를 삭제하는 것을 구현 자식이 부모와 통신 앞에서 부모가 자식에게 통신하기 위해서 props를 이용했고, props는 단방향 통신이고 위에서부터 아래로 흐리기 때문에 수정하면 안되는 read only 성격을 가진다고 하였다. 그러면, 반대로 자식이 부모에게 통신할려면 어떻게 해야 하나? 마찬가지로 props를 이용한다. 차이점은 props의 타입을 function 형태로 내려준다. 자식이 function 타입의 props를 받아서 호출하게 되면 부모의 function이 실행이 되므로 결국 자식이 부모와 통신하는 방법이 된다. 부모와 자식간의 통신, 자식이 부모와 통신하는 방법은 .. 리덕스 개념정리 - redux-actions 💥 redux-actions yarn add redux-actions 액션 생성 함수를 더 짧은 코드로 작성할 수 있게 해준다. 리듀서를 작성할 때 switch문이 아닌 handleActions라는 함수를 사용할 수 있게 해준다. 💥 createAction 액션 생성 함수를 만들어주는 함수이다. 직접 객체를 만들 필요 없어 훨씬 간단하다. createAction을 사용하지 않았을 때 const CHANGE_USER = 'user/CHANGE_USER'; // 액션 생성 함수 export const change_user = user => ({type: CHANGE_USER, user}); createAction을 사용했을 때 import { createAction } from 'redux-actions';.. error An unexpected error occurred: "C:\\Users\\hs\\AppData\\Local\\Yarn\\Cache\\v6\\npm-typescript-compare-0.0.2-7ee40a400a406c2ea0a7e551efd3309021d5f425-integrity\\node_modules\\typescript-compare\\.yarn-metadata.json: Unexpected end of JSON input". yarn add [package명] 을 쓸 때가 있다. 그런데 잘만되던 녀석이 error An unexpected error occurred: "C:\\Users\\hs\\AppData\\Local\\Yarn\\Cache\\v6\\npm-typescript-compare-0.0.2-7ee40a400a406c2ea0a7e551efd3309021d5f425-integrity\\node_modules\\typescript-compare\\.yarn-metadata.json: Unexpected end of JSON input". 같은 에러를 반복적으로 반환한하면 어떻게 해야할까? 위 에러를 해석해보면 yarn 의 metadata의 json파일에서 예기지 않은 input이 있다고 뜬다. 그렇기에 yarn의 me.. 리덕스사가 - takeLatest, takeEvery, all takeLatest takeLatest는 특정 액션 타입에 대하여 디스패치된 가장 마지막 액션만을 처리하는 함수입니다. 예를 들어서 특정 액션을 처리하고 있는 동안 동일한 타입의 새로운 액션이 디스패치되면 기존에 하던 작업을 무시 처리하고 새로운 작업을 시작합니다. takeEvery takeEvery는 특정 액션 타입에 대하여 디스패치되는 모든 액션들을 처리하는 것 all all 은 배열 안의 여러 사가를 동시에 실행시켜줍니다. 리덕스사가 - Generator, redux-saga, combineReducers 리덕스사가 redux-saga의 경우엔, 액션을 모니터링하고 있다가, 특정 액션이 발생하면 이에 따라 특정 작업을 하는 방식으로 사용합니다. 여기서 특정 작업이란, 특장 자바스크립트를 실행하는 것 일수도 있고, 다른 액션을 디스패치 하는 것 일수도 있고, 현재 상태를 불러오는 것 일수도 있습니다. redux-saga는 redux-thunk로 못하는 다양한 작업들을 처리 할 수 있습니다. 예를 들자면.. 비동기 작업을 할 때 기존 요청을 취소 처리 할 수 있습니다 특정 액션이 발생했을 때 이에 따라 다른 액션이 디스패치되게끔 하거나, 자바스크립트 코드를 실행 할 수 있습니다. 웹소켓을 사용하는 경우 Channel 이라는 기능을 사용하여 더욱 효율적으로 코드를 관리 할 수 있습니다 API 요청이 실패했을 때.. 이전 1 2 3 4 5 다음