Blog

HTML을 SVG로 변환하기

"Forking Chrome to turn HTML into SVG". 크로미움을 패치해서 HTML을 SVG로 변환하는 과정을 설명한 글이다. 특별한 장점이 있어서 변환을 했다고 생각되지는 않는데 재미있는 시도라고 생각된다. 요즘 SVG를 관심깊게 보고 있어서 더 그렇게 느껴지는 지도 모르겠다. 변환 과정에서 나온 기술적인 문제를 완전히 이해하지는 못했는데……

web | 2022-11-18 | Comments (0)

테이블에 border-radius가 적용되지 않을 때

테이블에 스타일을 적용할 때 보통 아래와 같은 스타일을 적용해서 제어를 한다. table { table-layout: fixed; border-collapse: collapse; } 이렇게 해야 셀의 너비를 원하는 대로 지정할 수 있고 셀에 선을 넣었을 때도 끊어지지 않고 붙어서 나오게 된다. 최근에 표에 border-radius가 적용되지 않는 현상을 발……

dev | 2022-10-15 | Comments (0)

SVG 애니메이션

20년 넘은 기술임에도 불구하고 SVG는 그동안 많이 사용되지 않았다. 로고같은 곳에 조금씩만 사용되었는데 요즘은 대부분의 아이콘을 SVG로 처리할 정도로 활용처가 많아졌다. 피그마나 제플린 같이 백터 그래픽을 쉽게 다루고 추출할 수 있게 해주는 도구의 발전도 한 몫 했다. 덕분에 나도 최근들어 SVG를 많이 사용하게 됐는데 CSS와의 조합이 아주 좋아서 ……

dev | 2022-08-28 | Comments (2)

각종 소프트웨어의 지원 종료 날짜를 알려주는 사이트

파이썬의 버전 관리 정보를 찾다가 발견한 사이트인데 endoflife.date라는 각종 프로젝트의 종료 시기를 안내해주는 사이트가 있다. 소프트웨어를 만들어 배포할 때 하위 호환성을 어디까지 유지해줘야 하나 고민하게 되는 경우가 많은데 그럴때 유용하게 사용할 수 있는 사이트이다. 물론 공식 지원이 끊겼다고 해서 사용자들이 없어지는 것은 아니지만 부족한 자원……

software | 2022-07-31 | Comments (0)

컨트롤, 알트, 쉬프트 키를 확인하는 방법

최신 브라우저들은 키보드 이벤트나 마우스 이벤트에 컨트롤(Ctrl), 알트(Alt), 쉬프트(Shift) 키들이 눌렸는지 알려주는 기능이 있다. 각각 event.ctrlKey, event.altKey, event.shiftKey를 이용해서 이벤트 발생 시에 이런 기능키가 눌렸는지 확인할 수 있다. 맥의 경우 컨트롤 키를 누르고 마우스 클릭을 하면 마우스 오……

dev | 2022-06-19 | Comments (1)

마키나락스

마키나락스(MakinaRocks)에 Frontend SW Engineer로 합류 했다. 마키나락스는 AI 스타트업으로 제조와 산업을 대상으로 하고 있다. MLOps 제품도 출시했는데 나도 제품 개발에 참여하게 될 것 같다. 회사 규모도 커지고 있고 채용도 많이 하고 있어서 당분간은 바쁘고 즐겁게 일하게 될 것 같아 기대된다.

work | 2022-06-02 | Comments (0)

접근성 기능 오용 사례

사용자가 직접 콘텐츠를 만들어서 올리는 서비스는 접근성 높은 콘텐츠를 올릴 수 있도록 기능을 제공하는 것이 중요하다. 가장 대표적인 접근성 기능이 사용자가 콘텐츠를 올릴 때 대체 텍스트나 자막을 같이 제공할 수 있게 하는 기능이다. 기능이 제공되고 있어도 사용자가 그 기능을 올바르게 이해하고 사용해야 하기 때문에 어려운 부분이 있다. 유투브는 사용자가 클로……

accessibility | 2022-05-30 | Comments (0)

scrollIntoView로 스크롤 제어

스크롤을 제어하는 가장 쉬운 방법은 URL 해시를 이용한 링크 이동이 있고 여기에 좀 더 정교한 조작이 필요하다면 Window.scrollTo()를 사용하는 방법이 있다. Window.scrollTo()를 사용하면 세밀한 조작에 애니메이션까지 가능하지만 대상의 위치를 Element.getBoundingClientRect()와 같은 기능을 사용해서 일일이 계……

dev | 2022-04-30 | Comments (0)

Form의 checkValidity 기능

서식 전송 전에 각 입력 박스에 오류메시지를 보여주기 위해서는 입력 요소의 oninvalid 이벤트를 이용하면 효과적으로 구현할 수 있다. 반면 요즘 많이 볼 수 있는 UX 중의 하나가 필수 요소를 모두 체크 했을 때 전송 버튼을 활성화하는 방식인데 개별 체크 박스를 검사히지 않고 전체 서식의 입력이 유효한지를 알 수 있다면 더 간단히 구현할 수 있다. 이……

dev | 2022-03-26 | Comments (1)

파이어폭스 번역 오류 수정

내 할일 목록에서 '폰툰 주소의 반영을 확인'해야 한다는 항목을 보고 무슨 내용인지 잠시 고민을 했다. 맥락도 적어 놓지 않아서 어디에 노출된 문장이었는지 기억해 내는데 조금 시간이 걸렸다. 영문은 `{ $count } login`과 복수형인 `{ $count } logins`이고 처음에는 `{ $count } 로그인`으로 번역했다가 `{ $count }회……

work | 2022-02-05 | Comments (0)