대단한 동현 블로그
Mobx when()으로 비동기 순서 보장하기
<frontend>/mobx 2025. 1. 10. 22:36

들어가며React + Mobx로 개발하다 보면 비동기 작업들 사이에서 순서 보장이 필요할 때가 있다.IAMBIT 기존 레거시는 각각 store마다 공통 state가 복제되어 있었다...이를 개선하기 위해 여러 개의 store에서 공통으로 사용하는 state들을 한 곳에서 중앙 관리 처리했다.그런 데문제 상황MainStore에서 심볼을 변경하고, 그 다음에 WebsocketManager에서 새로운 심볼에 대한 웹소켓 구독을 해야 하는 상황이었다.// 비즈니스 로직을 덜어낸 예시 코드class MainStore { @observable currentSymbol: string = "비트코인"; @action async changeSymbol(newSymbol: string) { runInAction..

article thumbnail
poe2 얼리엑세스 쇼케이스 다녀옴
카테고리 없음 2024. 11. 30. 16:16

갑자기 수요일에 문자가 왔다.토스 당근 컨퍼런스 추첨 죄다 떨구더니 이거 붙으려고 그랬구나!! poe2도 해볼 수 있었는데 한글 번역도 깔끔했고 기존 Poe1에서 불편했던 부분이 ui적으로 많이 개선되었다고 느낌한글 폰트도 어색하지 않게 잘 적용한 듯wasd로 움직이게 변경되었는데 생각보다 조작감도 괜찮았고 그래픽도 상당히 전작보다 발전한 게 보임. 갓겜이다 갓겜!! 기존 유저들 만든 서드파티로 제공하던 기능을 대부분 인게임에 구현했다고 했음. pob가 필요 없을수도 있을듯서드파티들이 개발하는데 많은 도움이 되었다 하셨는데 당사자들 행복사 하실듯 총괄 디렉터 조나단 님 영접했다. 용안에서 빛이 납니다죽기 전에 그라인딩기어게임즈에서 일해보고 싶다. 자기 프로덕트에 자부심 넘치시고 넘 멋지더라 미니게임하고 ..

article thumbnail
pretendard에 숫자 고정폭 적용하기
<frontend>/next.js 2024. 10. 27. 22:54

IAMBIT 거래소는 pretendard font를 메인으로 사용한다.pretendard는 숫자의 가로길이가 가변적인 폰트이다.때문에 아래 그림과 같은 문제가 발생한다. 이를 보고 디자이너님과 해결방안에 대해 이야기 나누어 보았다.가변폭 pretendard를 유기하고 고정폭 폰트로 수정한다. => 디자이너 리소스 많이 소모숫자만 고정폭 폰트로 수정 =>약간 짜친다, 디자이너 리소스 조금 소모때문에 다른 대안이 있나 싶어 찾아보니 pretendard 뿐만 아닌 OpenType을 지원하는 모든 폰트에 고정폭을 적용할 수 있는 방법이 있었다.nextjs, tailwindcss 환경에서 font OpenType 수정 방법이다.먼저 tailwind.config.ts 파일에 새로운 클래스를 추가한다.extend: ..

javascript 비동기 순서보장 잡기술
<frontend> 2024. 9. 29. 15:01

트레이딩 뷰 사용하다 보면 tvwidget관련 메서드 사용하다가 신기한걸 볼 수있다 웹소켓이 준비 되기 전에 관련 메서드를 사용해 버리면 차트가 터져버린다... 그럴 때 웹소켓 상태 확인하는 promise 만들어서 리턴하고setTimeout(()=>callback(), 0) 처럼 setTImeout으로 감싸 macrotaskQueue에 던져놓으면 microtaskQueue에 들어간 모든 promise들이 처리되기 전까지 대기 타게 처리할 수 있다. 뭔소린지 모르겠으면 아래 글 보세요 https://donghyk2.tistory.com/151 js는 비동기 큐가 2개다?vanilla JS로 핑퐁게임 SPA 사이트 프로젝트 하다가 겪은 일이다.커스텀 게임 방 리스트 페이지위 페이지에선 2가지 비동기 동작이 ..

article thumbnail
트레이딩뷰 무료 고급 차트 라이브러리 신청&사용
<frontend> 2024. 9. 29. 14:54

관련 자료가 진짜 없고 한국어로 된 최신 정보는 거의 없다시피 해서 정리한다.일단 거래소에서 사용하기 위해 차트, websocket streaming 렌더링 지원 하는 라이브러리를 찾는다면 트레이딩 뷰의 무료 고급 차트가 맞다.https://www.binance.com/en/futures/BTCUSDThttps://www.bitget.com/futures/usdt/BTCUSDT이 분야 최고 거래소들을 보면 죄다 tradingview 라이브러리를 사용 중이다.근데 바로 쓸 수가 없다. 비공개 리포에 저장되어 있음회사에서 public 용도로 사용한다는 증명이 담긴 신청서를 제출하고 허가받아야 한다.아래 링크에서 신청하자https://www.tradingview.com/advanced-charts/양식대로 작..

console.log는 비동기일수도 아닐수도 있습니다
<language>/javascript 2024. 9. 29. 14:25

트레이딩 뷰 라이브러리의 불친절한 공식문서를 해독하며 프로덕션에 붙이다 분봉이 제대로 붙지 않는 상황이 있어서 여기저기 콘솔을 찍어봐도 문제를 찾을 수가 없었다. js 이벤트루프 특성상 이 스코프 안에서 다른 요소가 간섭할 방법이 없다. 공유자원을 가지지 못하는 사실상 멀티프로세스에 가까운 web worker때문도 아니고, event bus 부분도 떼버려서 문제가 없었다. 진짜 귀신이 곡할 노릇인데… 범인은 console.log였다… object의 참조를 찍을때 이후에 그 object가 변하면 변한 값으로 찍히더라..왜 그러냐면 브라우저 최적화를 위해 그 라인에서 바로 찍지 않고 작업이 종료된 이후에 찍을 수도 안 찍을 수도 있다.. 브라우저마다 다름let obj = { count: 0 };console..