導入
Shadcn は、React プロジェクトで UI コンポーネントをコピー&ペーストするための頼りになるライブラリです。よく使用されるコンポーネントの 1 つは Tooltip で、これは @radix-ui/react-tooltip の上に構築されます。
デフォルトのツールチップは次のようになります:
ツールチップ矢印の追加
提供されているコンポーネントはそのまま使用しても問題なく機能しますが、ツールチップに矢印を追加するなど、さらにカスタマイズを追加したいと思うようになりました。インスピレーションを得るため、tremor.so の Tooltip コンポーネントを参考にしました。これも @radix-ui/react-tooltip に基づいています。
幸いなことに、@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 プロパティは、矢印の形状自体ではなく、要素の長方形の境界に適用されます。
ストロークプロパティの使用
矢印は 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>
これはうまく機能しますが、矢印の上の境界線はまだ表示されています。これを修正するには、別の方法を検討してみましょう。
ドロップ シャドウ オプションを調べる
もう 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>
これにより、矢印と境界線を備えた視覚的にシームレスなツールチップが作成されますが、ユースケースによっては、これが常に最も正確なソリューションであるとは限りません。
このソリューションは、開発時間を節約できるさまざまなカスタマイズ可能なツールチップ バリアントを提供する、Origin UI のツールチップ コンポーネントからインスピレーションを得ていることに言及する価値があります。
独自のカスタム SVG を使用するなど、さらにスタイリングしてみてはいかがでしょうか?
カスタムSVG矢印
私は Vercel の Web サイトによくアクセスしますが、そのドロップダウン ナビゲーション バー、特に 矢印 が目に留まりました。
どのように設計されたのか興味があったので、開発ツールを開いて要素を調べ、SVG 矢印を見つけました。次に、それをコピーして Figma に貼り付けて、詳しく見ていきました。
ツールチップの矢印としては、興味深いデザインの選択になるかもしれないと思いました。
位置決め
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 コンポーネントをカスタム デザインに置き換えることができます。完璧に動作するはずですよね?
そうですね、まだです。これを見てください: 矢印はトリガーの近くに配置されるのではなく、ツールチップの中央に固定されています。
この望ましくない動作は、各側の静的な位置を定義しただけであるために発生します。代わりに、この問題を解決するには動的な位置を使用する必要があります。
ダイナミックポジション
組み込みの Arrow コンポーネントを再度使用してみましょう。ツールチップの位置変更をシミュレートしながら開発ツールで Arrow コンポーネントを検査すると、SVG 要素が左の CSS プロパティを持つスパンでラップされていることがわかります。
この値は、ツールチップの位置に基づいて動的に変化します。この左側の CSS 値をキャプチャして、カスタム矢印コンポーネントに適用できます。
この左の値を追跡するには、MutationObserver を使用してそれを観察する必要があります。
<tooltipprimitives.arrow classname="border border-[var(--tooltip-border-color)] fill-[var(--tooltip-color)]" width="{12}" height="{7}" aria-hidden="true"></tooltipprimitives.arrow>
最終結果
期待どおりに動作していますか??
追伸ツールチップを左側または右側に表示したい場合は、上部の位置を調整するとよいでしょう。
結論
このアプローチは機能しますが、より簡単で柔軟なツールヒントのスタイルを可能にする UI ライブラリがあると思います。ただし、これに対する回避策を見つけることができてやりがいを感じています。他のオプションを検討することに興味がある場合は、このディスカッションをチェックしてみてください。
以上がShadcn のツールチップ矢印をカスタマイズする裏技的な方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

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

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

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

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

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

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

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


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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