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
ひとりNavigation API Advent Calendarの紹介 / Mita.ts #9
Search
Okuto Oyama
December 17, 2025
Technology
190
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
ひとりNavigation API Advent Calendarの紹介 / Mita.ts #9
Mita.ts #9
の発表資料
ひとりNavigation API - Qiita Advent Calendar 2025
Okuto Oyama
December 17, 2025
More Decks by Okuto Oyama
See All by Okuto Oyama
Navigation APIと見るSvelteKitのWeb標準志向
yamanoku
2
190
Shifting from MCP to Skills / ベストプラクティスの変遷を辿る
yamanoku
5
1.1k
SchooでVue.js/Nuxtを技術選定している理由
yamanoku
4
8.7k
たかがボタン、されどボタン ~button要素から深ぼるボタンUIの定義について~ / BuriKaigi 2026
yamanoku
1
470
DenoとJSRで実現する最速MCPサーバー開発記 / Building MCP Servers at Lightning Speed with Deno and JSR
yamanoku
2
660
転生したらTypeScriptのEnumだった件 ~型安全性とエコシステムの変化で挫けそうになっているんだが~ / TSKaigi 2025
yamanoku
0
74
React 18からのAPI useIDを使おう!/ Let's Use the useID API from React 18
yamanoku
0
180
リアクティブシステムの変遷から理解するalien-signals / Learning alien-signals from the evolution of reactive systems
yamanoku
3
2k
ブラウザ互換の重要性 - あらゆるユーザーに価値を届けるために必要なこと
yamanoku
0
400
Other Decks in Technology
See All in Technology
Oracle AI Database@AWS:サービス概要のご紹介
oracle4engineer
PRO
4
2.8k
新規ゲーム開発におけるAI駆動開発のリアル
202409e2
0
2.6k
関西に縁あるMicrosoft MVPsが語るCopilotの未来
kasada
0
1.2k
AI Engineering Summit Tokyo 2026 AIの前に、やることがある 〜医療データ企業の4フェーズ〜
dtaniwaki
0
1.9k
Unlocking the Apps
pimterry
0
240
Oracle AI Database@Google Cloud:サービス概要のご紹介
oracle4engineer
PRO
6
1.5k
Claude code Orchestra
ozakiomumkj
3
980
生成 AI × MCP で切り拓く次世代 SRE!自律型運用への挑戦と開発者体験の進化
_awache
0
160
新アーキテクチャ「TiDB X」解説とDedicated比較 TiDB Cloud Premiumのゲーム運用活用を検証
staffrecruiter
0
120
Terraformモジュールは、なぜ「魔境」化するのか
hayama17
1
190
LLMを「主役」にしないための 3つの原則
techtekt
PRO
0
120
サイバーセキュリティ概論 / Introduction to Cybersecurity
ks91
PRO
0
160
Featured
See All Featured
More Than Pixels: Becoming A User Experience Designer
marktimemedia
3
430
First, design no harm
axbom
PRO
2
1.2k
Information Architects: The Missing Link in Design Systems
soysaucechin
0
960
Evolving SEO for Evolving Search Engines
ryanjones
0
210
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
62
44k
Designing Experiences People Love
moore
143
24k
Stop Working from a Prison Cell
hatefulcrawdad
274
21k
Darren the Foodie - Storyboard
khoart
PRO
3
3.4k
How People are Using Generative and Agentic AI to Supercharge Their Products, Projects, Services and Value Streams Today
helenjbeal
1
200
End of SEO as We Know It (SMX Advanced Version)
ipullrank
3
4.2k
Marketing Yourself as an Engineer | Alaka | Gurzu
gurzu
0
210
Site-Speed That Sticks
csswizardry
13
1.2k
Transcript
ひとり Navigation API Advent Calendar
2025年
まもなく 終わりますね
今年は 何があったかな
フロントエンド エコシステムを 見渡してみる
• React Compiler v1リリース • Nuxt v4リリース • RemixのWeb標準による新アーキテクチャ •
Vitest Browser Mode安定化 • Biome v2リリース • Base UI v1リリース、shadcn/uiへの登用 • TypeScript Goでのネイティブ実装 • Vite +(plus) 発表 • npmリポジトリへのサプライチェーン攻撃 • React2Shell 等
私が注目した 2025年の出来事
Interop 2025
Interop?
Web APIの クロスブラウザ 相互運用性を 高めるプロジェクト
• CSS Anchor positioning • backdrop-filter • Core Web Vitals
• <details> element • Layout • JavaScript Modules • Navigation API • Pointer and Mouse events • @scope • scrollend event • Storage Access API • text-decoration • URLPattern • View Transition API • WebAssembly • Web Compat • WebRTC • Writing modes • Mutation Event 削除
私が 注目している Web API
Navigation API
これは何が できるの?
SPAの ユーザー体験を 向上させる Web API
もう少し 具体的に言うと
SPA開発に必要な History APIを 使いやすくしたもの
そもそも History APIって?
ブラウザの 閲覧履歴を 制御するもの
history.forward()
history.back()
history.go()
history.pushState() history.replaceState()
scrollRestoration
History APIは SPAのどの部分で 活用されてる?
クライアント ルーティング
History APIは SPAの構築に 必要なWeb API
しかしながら
History API には 問題があります
履歴を残すのが 難しい
履歴はふとした リンク操作で 書き換わってしまう
Safari iOSでの pushStateの 回数制限
30秒間に100回の pushState呼び出しで SecurityError
遷移処理を止めると 履歴が差し変わる ことがある
履歴を復元する 処理を作らないと いけない
アクセシビリティ観点
手続き的な フォーカス管理が やりづらい
たいへん
そこで登場
Navigation API
履歴の管理を 永続的なものに
遷移途中に 割り込み処理を 入れられるように
フォーカス管理も しやすくなった
いいね
ところで
None
型情報は?
TypeScript 3.9では 一部型情報が 使えます
2つ以上の ブラウザエンジンが 対応したら 正式に反映される
Chrome 102 Release date 2022-05-24 Edge 102 Release date 2022-05-31
Safari 26.2 Release date 2025-12-12 Firefox 147 Release date 2026-01-13
来年には 全ブラウザで 安定して使える (予定)
つまり
2026年は Navigation API 元年
使うなら ちゃんと 理解したい
予習しておこう
そういえば
今って 12月ですね
12月といえば
Advent Calendar
というわけで
ひとりNavigation API Advent Calendarをやっています!
• Navigation APIとは何? • 一次情報源まとめ ◦ Navigation API、History API ◦
ルーティングライブラリ集 • History APIの問題点 • Navigation APIインターフェイス、メソッドを見る • interceptとは何? • クライアントサイドルーティングを実装してみる • React Router、Vue RouterのHistory API実装を見る • uhyoさんが作ったルーティングライブラリの実装を見る 等
あと8日
最後まで 走り切ります
#ひとりNavigation_API_Advent_Calendar
発表者紹介
• 一児の父 • 会社員 • PodCast User ◦ お元気ですか .fm
• @yamanoku ◦ X ◦ GitHub ◦ BlueSky やまのく
ご清聴 ありがとう ございました