検索
ホームページウェブフロントエンドCSSチュートリアルShadcn のツールチップ矢印をカスタマイズする裏技的な方法

導入

Shadcn は、React プロジェクトで UI コンポーネントをコピー&ペーストするための頼りになるライブラリです。よく使用されるコンポーネントの 1 つは Tooltip で、これは @radix-ui/react-tooltip の上に構築されます。

デフォルトのツールチップは次のようになります:

Hacky Way to Customize Shadcn’s Tooltip Arrows

ツールチップ矢印の追加

提供されているコンポーネントはそのまま使用しても問題なく機能しますが、ツールチップに矢印を追加するなど、さらにカスタマイズを追加したいと思うようになりました。インスピレーションを得るため、tremor.so の Tooltip コンポーネントを参考にしました。これも @radix-ui/react-tooltip に基づいています。

Hacky Way to Customize Shadcn’s Tooltip Arrows

幸いなことに、@radix-ui/react-tooltip には Arrow コンポーネントが含まれているため、矢印の追加は簡単です。これを Content コンポーネント内に含めるだけです。

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 コンポーネントのスタイルを設定する必要があります。いくつかのアプローチを見てみましょう:

素朴なアプローチ

Tailwind クラスを使用して矢印に境界線を直接追加するのが良い出発点と思われます:

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

しかし、このアプローチは期待どおりに機能しません。 border プロパティは、矢印の形状自体ではなく、要素の長方形の境界に適用されます。

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

ドロップ シャドウ オプションを調べる

もう 1 つの方法は、ドロップシャドウを使用して境界線をシミュレートすることです。

<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 の Web サイトによくアクセスしますが、そのドロップダウン ナビゲーション バー、特に 矢印 が目に留まりました。

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 矢印の位置は、ツールチップの配置 (、または ) によって異なります。 Content コンポーネントは、位置を動的に調整するために使用できるデータ側属性を公開します。

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 コンポーネントを再度使用してみましょう。ツールチップの位置変更をシミュレートしながら開発ツールで 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 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
WordPressブロックと要素にボックスシャドウを追加しますWordPressブロックと要素にボックスシャドウを追加しますMar 09, 2025 pm 12:53 PM

CSS Box-Shadowおよびアウトラインプロパティは、WordPress 6.1でTheme.jsonサポートを獲得しました。実際のテーマでどのように機能するか、そしてこれらのスタイルをWordPressブロックと要素に適用するために必要なオプションのいくつかの例を見てみましょう。

Smart Forms Frameworkを使用してJavaScript連絡フォームを作成するSmart Forms Frameworkを使用してJavaScript連絡フォームを作成するMar 07, 2025 am 11:33 AM

このチュートリアルでは、Smart Formsフレームワークを使用して、プロフェッショナルなJavaScriptフォームの作成を示しています(注:使用できなくなりました)。 フレームワーク自体は利用できませんが、原則とテクニックは他のフォームビルダーに関連しています。

スクリーンリーダーの分解:アクセス可能なフォームとベストプラクティススクリーンリーダーの分解:アクセス可能なフォームとベストプラクティスMar 08, 2025 am 09:45 AM

これは、フォームアクセシビリティについて行った小さなシリーズの3番目の投稿です。 2番目の投稿を逃した場合は、「ユーザーフォーカスの管理:Focus-Visible」をご覧ください。で

満足している属性を持つインラインテキストエディターを作成します満足している属性を持つインラインテキストエディターを作成しますMar 02, 2025 am 09:03 AM

インラインテキストエディターの構築は些細なものではありません。 このプロセスは、ターゲット要素を編集可能にすることから始まり、その過程で潜在的なSyntaxerrorの例外を処理します。 エディターの作成 このエディターを構築するには、コンテンツを動的に変更する必要があります

GraphQLキャッシングの使用GraphQLキャッシングの使用Mar 19, 2025 am 09:36 AM

最近GraphQLの作業を開始した場合、またはその長所と短所をレビューした場合、「GraphQLがキャッシュをサポートしていない」または

最初のカスタムSvelteトランジションを作成します最初のカスタムSvelteトランジションを作成しますMar 15, 2025 am 11:08 AM

Svelte Transition APIは、コンポーネントがカスタムSVELTE遷移を含むドキュメントを入力または離れるときにアニメーション化する方法を提供します。

5つの最高のPHPフォームビルダー(および3つの無料スクリプト)を比較する5つの最高のPHPフォームビルダー(および3つの無料スクリプト)を比較するMar 04, 2025 am 10:22 AM

この記事では、Envato Marketで入手可能なPHPフォームのビルダースクリプトを説明し、機能、柔軟性、デザインを比較します。 特定のオプションに飛び込む前に、PHPフォームのビルダーが何であるか、そしてそれを使用する理由を理解しましょう。 PHPフォーム

node.jsとexpressのMulterを使用してファイルアップロードしますnode.jsとexpressのMulterを使用してファイルアップロードしますMar 02, 2025 am 09:15 AM

このチュートリアルは、node.js、Express、およびMulterを使用してファイルアップロードシステムを構築することをガイドします。 単一および複数のファイルのアップロードをカバーし、後で検索するためにMongoDBデータベースに画像を保存することさえ示します。 まず、プロジェックをセットアップします

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衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、