Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Release Yamada UI v2
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Hirotomo Yamada
October 17, 2025
Technology
650
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Release Yamada UI v2
Hirotomo Yamada
October 17, 2025
More Decks by Hirotomo Yamada
See All by Hirotomo Yamada
React ABC Questions
hirotomoyamada
0
980
Other Decks in Technology
See All in Technology
あなたの AI ワークスペースに、 専門コーダーを連れてくる - Amazon Quick Desktop 最新情報
kawaji_scratch
1
130
2026.06.13_AI時代に事業会社が「SIer出身エンジニア」を求める理由 / Why Businesses Seek Engineers with a System Integrator Background in the AI Era
jumtech
0
1k
やさしいA2A入門
minorun365
PRO
11
1.7k
ポケモンの型をTypeScriptの型システムで表現してみた
subroh0508
0
370
2026TECHFRESH畢業分享會 - AI 時代的人生存檔點
line_developers_tw
PRO
0
670
AAIFに入ってみた ~内から見えるコミュニティ動向~
sato4
0
130
FDE という解 ― 暗黙知と明示知をつなぐ、伴走型エンジニアリング ―
otanet
0
130
RAG を使わないという選択肢
tatsutaka
1
110
[モダンアプリ勉強会]今更聞けないGit/GitHub入門
tsukuboshi
0
360
新規事業を牽引する技術選定 〜フルスタックTypeScript開発の実践事例〜
nullnull
3
380
白金鉱業Meetup_Vol.24_「AIエージェントは分けるほど良い」は本当か? / Is it true that “the more you divide AI agents, the better”?
brainpadpr
1
220
Dario Amodi『Policy on the AI Exponential』を理解する
nagatsu
0
210
Featured
See All Featured
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
16
2k
Getting science done with accelerated Python computing platforms
jacobtomlinson
2
220
Navigating the moral maze — ethical principles for Al-driven product design
skipperchong
2
390
Imperfection Machines: The Place of Print at Facebook
scottboms
270
14k
Mind Mapping
helmedeiros
PRO
1
240
A Tale of Four Properties
chriscoyier
163
24k
[RailsConf 2023] Rails as a piece of cake
palkan
59
6.7k
The Organizational Zoo: Understanding Human Behavior Agility Through Metaphoric Constructive Conversations (based on the works of Arthur Shelley, Ph.D)
kimpetersen
PRO
0
360
Noah Learner - AI + Me: how we built a GSC Bulk Export data pipeline
techseoconnect
PRO
0
200
Designing for Timeless Needs
cassininazir
1
250
svc-hook: hooking system calls on ARM64 by binary rewriting
retrage
2
290
Highjacked: Video Game Concept Design
rkendrick25
PRO
1
380
Transcript
Yamada UI v2をリリースする
Profile Produced Contributing Hirotomo Yamada Developer of Yamada UI. Designer,
design system and UI engineer. I work for
Yamada UI v2をリリースする
リリースします
🎉
Yamada UI とは 他は、省略します。 日本発のReact UIライブラリです
新しい機能
CLI - セットアップ CLIを使用すると、プロジェクトで Yamada UIのセットアップを簡単に行うことができるようになりました。 initコマンドを実行すると、次のプロンプトが表示されます。
CLI - ダウンロード 2つの方法でコンポーネントを提供します。 1つは、CLIからコンポーネントをダウンロードする新しい方法。もう 1つは、 モジュールからコンポーネントをインポートする従来通りの方法です。 ソースコードをダウンロードすることにより、コンポーネントやフックの 初期値やロジックをカスタマイズすることがで き、ロジックなどで不具合があった場合は、直接修正する
ことができます。
CLI - ダウンロード ソースコードをダウンロードしてカスタマイズしても、 CLIのdiffやupdateを行うことで、ソースコードを簡単に更新する ことができます。もし、あなたの修正と競合しても Gitの競合の提示方法と同じ ように表示され、簡単に解決することが できます。
コンポーネント - 名前空間インポート 名前空間を使用してコンポーネントをインポートすることができるようになりました。 従来のコンポーネントを個別にインポートすることは、引き続き可能です。 但し、名前空間の兼ね合いで名前が変更されたコンポーネントがあります。 例えば、Accordionの場合は、AccordionRootに変更されています。
コンポーネント - createComponent createComponentを使用すると、バリアントなど条件付きスタイル をサポートするコンポーネントを作成することがで きます。createSlotComponentを使用すると、スロット付きコンポーネントを簡単に作成できます。 • BEMの命名規則に準拠した classNameを自動で生成する。 •
柔軟な記述方法ができる。 • 条件付きスタイルの条件は、 OR・AND・正規表現が選択でき、柔軟にマッチさせることができる。 • 条件付きスタイルで使用する propsは、スタイルを計算した後、 自動的に除外される。 • propsを多段階計算する。 • propsは、mergePropsを使用して、消失を防ぎながらマージ される。 • コンテキストを生成するので、コンテキスト内の同コンポーネントに propsを一括設定できる。
defineComponentStyleでスタイルを定義し、 createComponentから提供されるメソッドでコンポーネントを作成しま す。 コンポーネント - createComponent
BEMの命名規則に準拠した classNameを自動で生成する。 コンポーネント - createComponent
コンポーネントは柔軟な記述ができます。 コンポーネント - createComponent 条件付きスタイルのみ使用し、ロジックを持たないコンポーネントは、 HTMLの要素を指定するだけです。 従来のような関数コンポーネントも定義できます。
条件付きスタイルの条件は、 OR・AND・正規表現が選択でき、柔軟にマッチさせることができる。 コンポーネント - createComponent 配列にすることでORになります。 正規表現を使用できます。
propsを多段階計算する。 コンポーネント - createComponent 第一引数は、初期値の propsです。提供されるpropsによって上書きされるか、 マージされます。 今回のケースは、aria-labelは上書きされ、onClickの処理はマージされます。 第二引数以降は、オブジェクトまたは関数を設定されることで 多段階計算またはマージされます。
今回のケースの場合、 orientationはdata-orientationに変換され、DOMの要素にセットされません。
コンポーネント - createComponent 提供されたPropsContextを使用すると、子要素にあるコンポーネントの propsを一括で設定することができます。 上記の例では、BadgePropsContextの子要素にあるBadgeは、すべてvariantが”outline”になります。
コンポーネント - mergeProps mergePropsを使用すると、propsの消失を防ぎながらマージ を簡単に行うことができます。従来は、提供される props を配慮しながらコンポーネントを作成する必要がありました。 mergePropsを使用すると、提供される propsを配慮する ことなく、コンポーネントの作成に集中することができます。
Before After
コンポーネント - ポリモーフィズム 従来のasに加えて、asChildを追加しました。asは、コンポーネント自体の要素を変更するに対して、 asChildは、コン ポーネントの機能やスタイルを子要素に組み込む ために使用します。 as asChild
Style Props - CSSカスタムプロパティ・値関数 Style Propsで簡単にCSSカスタムプロパティを設定できるようになりました。 また、テーマのトークンを参照することができます。 Style Propsの値でCSS値関数を使用する場合に、各関数が対応するテーマの トークンを参照することができるように
なりました。
Style Props - インターポレーション Style Propsの値で簡単にCSSカスタムプロパティを参照することができるようになりました。 また、テーマのトークンを参照することができます。これは、テーマのトークンと紐づいていないプロパティに、別の テーマのトークンを設定するのに便利です。 borderなどの一括指定プロパティ で使用すると便利です。
Style Props - アットルール Style Propsにアットルールが追加されました。 コンテナクエリもサポートしています。
Style Props - アニメーション 以前のアニメーションは、 useAnimationを使用していました。これからは、 Style Propsから直接設定することができる ようになりました。 After
Before
アクセシビリティ - 国際化 アクセシビリティを向上させるため、すべてのコンポーネントで組み込まれている文字列から日付・数値のフォーマット まで、30以上の言語をサポートしました。 日本語(日本) 英語(イギリス) 英語(米国) アラビア語(アラブ首長国連邦) ブルガリア語(ブルガリア)
クロアチア語(クロアチア) チェコ語(チェコ共和国) デンマーク語(デンマーク) オランダ語(オランダ) エストニア語(エストニア) フィンランド語(フィンランド) フランス語(カナダ) フランス語(フランス) ドイツ語(ドイツ) ギリシャ語(ギリシャ) ヘブライ語(イスラエル) ハンガリー語(ハンガリー) イタリア語(イタリア) ラトビア語(ラトビア) リトアニア語(リトアニア) ノルウェー語(ノルウェー) ポーランド語(ポーランド) ポルトガル語(ブラジル) ルーマニア語(ルーマニア) ロシア語(ロシア) セルビア語(セルビア) スロバキア語(スロバキア) スロベニア語(スロベニア) スペイン語(スペイン) スウェーデン語(スウェーデン) トルコ語(トルコ) ウクライナ語(ウクライナ) 中国語(簡体字) 中国語(繁体字) 韓国語(韓国) これらの言語は、I18nProviderの言語データから簡単に更新することができ、新しい言語データを追加することも可 能です。また、バンドルサイズは言語データを削除すれば最適化できます。
ありがとうございました X @hirotomoyamada https://x.com/hirotomoyamada GitHub リポジトリ https://github.com/yamada-ui/yamada-ui ドキュメントサイト https://yamada-ui.com