본문 바로가기

전체 글370

Nextjs 14 server component build 과정

yarn build를 로컬에서 실행했습니다.빌드 중에 server-component에서 에러가 발생했습니다.해당 server-component에서는 async로 API를 호출합니다.API응답에서 값이 없으면, throw new Error 던지게 되어 있습니다.  빌드 중에 API가 실제로 호출되지는 않은 것 같습니다. throw new Error 때문에 발생한 현상인 것 같습니다.const [sbTokenVO] = await getSendbirdToken() if (!sbTokenVO?.key || !sbTokenVO?.token) { // 발생하는 경우: throw new Error('채팅 서버 접속 정보를 가져오는데 실패했습니다.') // error.tsx로 이동될거임 // retu.. 2025. 1. 21.

[React+Formik] 배열 데이터 Form에서 list item 컴포넌트에 index, propsDrilling 이슈

지금 당장으로서는 propsDrilling이 가장 안전하고 직관적인 방법으로 판단되었습니다.bypass하는 컴포넌트가 있게되지만, 복잡도 증가보다는 낫다고 판단했습니다. 2024. 10. 16.

[CSS] flex-grow, flex-shrink, flex-basis 알아보기

flex-grow(기본값: 0) 부모 영역에서 자식 요소들이 부모 영역에 여백이 있으면, 채우기 정도를 요소마다 설정할 수 있게 해주는 옵션이다. 기본값이 0이니까, 아무런 설정을 안 하면, flex로 한 부모 요소의 자식요소들은 빈 영역이 있어도 채우지 않는다. flex-grow: 1로 설정한 자식요소는 flex의 부모 요소의 빈공간을 채운다. flex-shrink(기본값: 1) 자식 요소들의 크기들이, 부모 요소보다 클 경우, 자식요소들의 크기를 부모 요소의 크기에 맞춰서 줄어드는 정도를 설정할 수 있게 해주는 옵션이다. 기본값이 1이므로, 자식요소들이 부모 요소의 크기를 넘어도, 자식요소들이 부모 요소 밖으로 튀어나오지 않는다. 만약, flex-shrink: 0으로 전부, 자식요소를 설정하고, 부모.. 2023. 3. 20.

[Vue] 조건부 렌더링 에러

consoleObservable.js?3605:26 TypeError: Cannot read properties of undefined (reading '_transitionClasses') at Array.updateClass (vue.runtime.esm.js?2b0e:7377:1) at patchVnode (vue.runtime.esm.js?2b0e:6887:1) at updateChildren (vue.runtime.esm.js?2b0e:6768:1) at patchVnode (vue.runtime.esm.js?2b0e:6894:1) at VueComponent.patch [as __patch__] (vue.runtime.esm.js?2b0e:7062:1) at Vue._update (vue.ru.. 2023. 3. 14.

[라이브러리] cookie-parser npm 라이브러리는 뭘까?

정의 https://www.npmjs.com/package/cookie-parser Parse Cookie header and populate 'req.cookies' with an object keyed by the cookie names. 쿠키 헤더를 구문 분석하고 쿠키 이름으로 키가 지정된 개체로 'req.cookies'를 채웁니다. 왜 쓸까? Node.js 서버를 개발할 때 쓴다. 클라이언트(브라우저)로부터 http 요청 header에 cookie를 받았을 때, 쉽게 cookie를 사용하기 위해서 쓴다. export default async (req: Request, res: Response, next: NextFunction) => { try { console.log("!!!!!!!!!!!!!!.. 2023. 3. 2.

[CSS] 색깔있는 이미지 회색으로 처리하기

img { filter: grayscale(100%); } 결과 2023. 2. 25.

[웹 브라우저 & 모바일] 모바일 기기에서 브라우저의 인풋이 focus 되었을 때, 가상키보드 안 생기게 하는 방법

두가지 방법이 있겠다. 2023. 2. 23.

[github] 원격지에 dev 브랜치를 커밋 이전 버전으로 반영하기(덮어씌우기)

push -f는 desktop이나, vscode의 github plugin 그리고 github 웹 페이지에서 불가능하다. 오로지 명령어로만 가능하다. 로컬에 커밋 이전 브랜치가 있어서, 이 브랜치를 다음 명령어로 dev에 push -f했으나 잘 되지 않았다. 해결 방법 로컬에 dev 브랜치를 삭제했다. 원격 dev에 반영할 코드를 'dev'라는 브랜치명으로 로컬에 똑같이 만든다. 명령어 입력 : git push -f origin dev 2023. 2. 21.

[Javascript] 텍스트 클립보드 복사하기 코드

// Get the text to be copied const textToCopy = "Hello, world!"; // Create a temporary input element const tempInput = document.createElement("input"); tempInput.setAttribute("type", "text"); tempInput.setAttribute("value", textToCopy); document.body.appendChild(tempInput); // Select the text tempInput.select(); // Copy the text to the clipboard document.execCommand("copy"); // Remove the tempor.. 2023. 2. 19.

[Vue] textarea에 개행마다, 높이 늘어나고, shift+enter 개행이고, enter하면 서브밋하는 코드

2023. 2. 19.