찾다
웹 프론트엔드CSS 튜토리얼Shadcn의 툴팁 화살표를 사용자 정의하는 해킹 방법

소개

Shadcn은 React 프로젝트의 UI 구성요소 복사-붙여넣기를 위한 라이브러리입니다. 일반적으로 사용되는 구성 요소 중 하나는 @radix-ui/react-tooltip 위에 구축된 Tooltip입니다.

기본 도구 설명은 다음과 같습니다.

Hacky Way to Customize Shadcn’s Tooltip Arrows

도구 설명 화살표 추가

제공된 구성요소는 기본적으로 잘 작동하지만 툴팁에 화살표를 추가하는 등 더 많은 사용자 정의를 추가하고 싶었습니다. 영감을 얻기 위해 역시 @radix-ui/react-tooltip을 기반으로 하는 tremor.so의 Tooltip 구성 요소를 참조했습니다.

Hacky Way to Customize Shadcn’s Tooltip Arrows

다행히 @radix-ui/react-tooltip에 Arrow 구성 요소가 포함되어 있으므로 화살표를 추가하는 것은 간단합니다. 콘텐츠 구성요소 안에 포함시키기만 하면 됩니다.

import * as TooltipPrimitives from '@radix-ui/react-tooltip'

export default () => (
  <tooltipprimitives.provider>
    <tooltipprimitives.root>
      <tooltipprimitives.trigger></tooltipprimitives.trigger>
      <tooltipprimitives.portal>
        <tooltipprimitives.content>
          <tooltipprimitives.arrow></tooltipprimitives.arrow> // Add the Arrow component here
        </tooltipprimitives.content>
      </tooltipprimitives.portal>
    </tooltipprimitives.root>
  </tooltipprimitives.provider>
)

그런데 화살표를 포함한 전체 툴팁 주위에 테두리를 추가하고 싶다면 어떻게 해야 할까요?

도구 설명 테두리 추가

이를 달성하려면 화살표 구성 요소의 스타일을 지정해야 합니다. 몇 가지 접근 방식을 살펴보겠습니다.

순진한 접근 방식

Tailwind 클래스를 사용하여 Arrow에 직접 테두리를 추가하는 것이 좋은 출발점인 것 같습니다.

<tooltipprimitives.arrow classname="border border-[var(--tooltip-border-color)] fill-[var(--tooltip-color)]" width="{12}" height="{7}" aria-hidden="true"></tooltipprimitives.arrow>

그러나 이 접근 방식은 예상대로 작동하지 않습니다. 테두리 속성은 화살표 모양 자체가 아닌 요소의 직사각형 경계에 적용됩니다.

Hacky Way to Customize Shadcn’s Tooltip Arrows

스트로크 속성 사용

화살표는 SVG 요소이므로 스트로크 속성을 사용하여 테두리를 정의할 수 있습니다.

<tooltipprimitives.arrow classname="border-none fill-[var(--tooltip-color)]" stroke="var(--tooltip-border-color)" stroke-width="2" width="{12}" height="{7}" aria-hidden="true"></tooltipprimitives.arrow>

이렇게 하면 더 잘 작동하지만 화살표의 위쪽 테두리는 여전히 표시됩니다. 이 문제를 해결하려면 다른 방법을 살펴보겠습니다.

Hacky Way to Customize Shadcn’s Tooltip Arrows

드롭 섀도우 옵션 살펴보기

또 다른 방법은 그림자를 사용하여 테두리를 시뮬레이션하는 것입니다.

<tooltipprimitives.arrow classname="-my-px border-none fill-[var(--tooltip-color)] drop-shadow-[0_1px_0_red]" width="{12}" height="{7}" aria-hidden="true"></tooltipprimitives.arrow>

이렇게 하면 화살표와 테두리가 포함된 시각적으로 원활한 도구 설명이 생성되지만 사용 사례에 따라 항상 가장 정확한 솔루션이 아닐 수도 있습니다.

Hacky Way to Customize Shadcn’s Tooltip Arrows

이 솔루션은 개발 시간을 절약할 수 있는 다양한 사용자 정의 가능한 도구 설명 변형을 제공하는 Origin UI의 도구 설명 구성 요소에서 영감을 받았다는 점을 언급할 가치가 있습니다.

나만의 맞춤형 SVG를 사용하는 등 더욱 스타일을 살려보는 것은 어떨까요?

사용자 정의 SVG 화살표

저는 Vercel의 웹사이트를 자주 방문하는데, 특히 화살표가 제 눈길을 끌었습니다.

Hacky Way to Customize Shadcn’s Tooltip Arrows

어떻게 디자인됐는지 궁금해서 개발 도구를 열고 요소를 살펴보니 SVG 화살표가 보였습니다. 그런 다음 자세히 살펴보기 위해 복사하여 Figma에 붙여넣었습니다.

Hacky Way to Customize Shadcn’s Tooltip Arrows

툴팁 화살표에 대한 흥미로운 디자인 선택이 될 수 있다고 생각했습니다.

포지셔닝

Hacky Way to Customize Shadcn’s Tooltip Arrows

SVG 화살표 위치는 도구 설명의 위치(상단, 하단, 왼쪽 또는 오른쪽)에 따라 다릅니다. 콘텐츠 구성 요소는 위치 지정을 동적으로 조정하는 데 사용할 수 있는 데이터 측 속성을 노출합니다.

import * as TooltipPrimitives from '@radix-ui/react-tooltip'

export default () => (
  <tooltipprimitives.provider>
    <tooltipprimitives.root>
      <tooltipprimitives.trigger></tooltipprimitives.trigger>
      <tooltipprimitives.portal>
        <tooltipprimitives.content>
          <tooltipprimitives.arrow></tooltipprimitives.arrow> // Add the Arrow component here
        </tooltipprimitives.content>
      </tooltipprimitives.portal>
    </tooltipprimitives.root>
  </tooltipprimitives.provider>
)

다음으로 내장된 도구 설명 Arrow 구성 요소를 맞춤형 디자인으로 교체할 수 있습니다. 완벽하게 작동해야겠죠?

Hacky Way to Customize Shadcn’s Tooltip Arrows

아직은 아닙니다. 이것을 보세요: 화살표가 트리거 근처에 위치하지 않고 툴팁 중앙에 붙어 있습니다.

Hacky Way to Customize Shadcn’s Tooltip Arrows

이러한 바람직하지 않은 동작은 각 측면에 대해 정적 위치만 정의했기 때문에 발생합니다. 대신 이 문제를 해결하려면 동적 위치를 사용해야 합니다.

동적 위치

내장된 Arrow 구성 요소를 다시 사용해 시작해 보겠습니다. 도구 설명 위치 변경을 시뮬레이션하는 동안 개발 도구에서 화살표 구성 요소를 검사하면 SVG 요소가 왼쪽 CSS 속성이 있는 범위에 래핑되어 있음을 알 수 있습니다.

Hacky Way to Customize Shadcn’s Tooltip Arrows

이 값은 툴팁 위치에 따라 동적으로 변경됩니다. 이 왼쪽 CSS 값을 캡처하여 사용자 정의 화살표 구성 요소에 적용할 수 있습니다.

이 왼쪽 값을 추적하려면 MutationObserver를 사용하여 관찰해야 합니다.

<tooltipprimitives.arrow classname="border border-[var(--tooltip-border-color)] fill-[var(--tooltip-color)]" width="{12}" height="{7}" aria-hidden="true"></tooltipprimitives.arrow>

최종 결과

지금은 예상대로 작동하고 있나요 ??

Hacky Way to Customize Shadcn’s Tooltip Arrows

추신 툴팁을 왼쪽이나 오른쪽에 표시하고 싶다면 상단 위치를 조정하는 것이 좋습니다.

결론

이 접근 방식이 효과적이기는 하지만 더 쉽고 유연한 툴팁 스타일을 허용하는 UI 라이브러리가 있을 것이라고 확신합니다. 그러나 이에 대한 해결 방법을 찾은 것은 보람 있는 일이라고 생각합니다. 다른 옵션을 알아보고 싶다면 이 토론을 확인해 보세요.

위 내용은 Shadcn의 툴팁 화살표를 사용자 정의하는 해킹 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
CSS 그리드는 무엇입니까?CSS 그리드는 무엇입니까?Apr 30, 2025 pm 03:21 PM

CSS 그리드는 복잡하고 반응이 좋은 웹 레이아웃을 만드는 강력한 도구입니다. 디자인을 단순화하고 접근성을 향상 시키며 이전 방법보다 더 많은 제어를 제공합니다.

CSS Flexbox 란 무엇입니까?CSS Flexbox 란 무엇입니까?Apr 30, 2025 pm 03:20 PM

기사는 반응 형 설계에서 공간의 효율적인 정렬 및 분포를위한 레이아웃 방법 인 CSS Flexbox에 대해 설명합니다. Flexbox 사용을 설명하고 CSS 그리드와 비교하고 브라우저 지원 세부 사항을 설명합니다.

CSS를 사용하여 웹 사이트를 반응하게 만드는 방법은 무엇입니까?CSS를 사용하여 웹 사이트를 반응하게 만드는 방법은 무엇입니까?Apr 30, 2025 pm 03:19 PM

이 기사는 Viewport Meta 태그, 유연한 그리드, 유체 미디어, 미디어 쿼리 및 상대 장치를 포함하여 CSS를 사용하여 반응 형 웹 사이트를 만드는 기술에 대해 설명합니다. 또한 CSS 그리드 및 Flexbox를 함께 사용하여 CSS 프레임 워크를 권장합니다.

CSS 박스 크기 부동산은 무엇을합니까?CSS 박스 크기 부동산은 무엇을합니까?Apr 30, 2025 pm 03:18 PM

이 기사는 요소 치수 계산 방법을 제어하는 ​​CSS 박스 크기 속성에 대해 설명합니다. Content-Box, Border-Box 및 Padding-Box와 같은 값과 레이아웃 설계 및 형태 정렬에 미치는 영향을 설명합니다.

CSS를 사용하여 어떻게 애니메이션 할 수 있습니까?CSS를 사용하여 어떻게 애니메이션 할 수 있습니까?Apr 30, 2025 pm 03:17 PM

기사는 CSS, 주요 특성 및 JavaScript와 결합 된 애니메이션 작성에 대해 논의합니다. 주요 문제는 브라우저 호환성입니다.

CSS를 사용하여 프로젝트에 3D 변환을 추가 할 수 있습니까?CSS를 사용하여 프로젝트에 3D 변환을 추가 할 수 있습니까?Apr 30, 2025 pm 03:16 PM

기사는 3D 변환, 주요 속성, 브라우저 호환성 및 웹 프로젝트에 대한 성능 고려 사항에 대한 CSS 사용에 대해 논의합니다. (문자 수 : 159)

CSS에 기울기를 추가 할 수있는 방법은 무엇입니까?CSS에 기울기를 추가 할 수있는 방법은 무엇입니까?Apr 30, 2025 pm 03:15 PM

이 기사는 CSS 그라디언트 (선형, 방사형, 반복)를 사용하여 웹 사이트 비주얼을 향상시키고 깊이, 초점 및 현대적인 미학을 추가합니다.

CSS의 의사 요소는 무엇입니까?CSS의 의사 요소는 무엇입니까?Apr 30, 2025 pm 03:14 PM

기사는 CSS의 의사 요소, HTML 스타일을 향상시키는 데 사용 및 의사 급의 차이점에 대해 설명합니다. 실제 사례를 제공합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)