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
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
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
Claude Codeを組織で使いこなす— サーバサイドAIエージェント運用の実践知
techtekt
PRO
0
210
もりもり新機能を一挙紹介! AgentCoreに入門して、AWS上にAIエージェントを構築しよう
minorun365
PRO
6
830
LLMと共に進化するプロセスを目指して
ymatsuwitter
12
3.3k
地元にいないローカルオーガナイザーの立ち回り
uvb_76
1
560
先取りMaven4 ~16年ぶりのメジャーアップデート、その進化とは?~
ogiwarat
0
140
はじめてのDatadog
kairim0
0
280
Rubyで音を視る
ydah
1
100
noUncheckedIndexedAccess、3時間、1万円。 / noUncheckedIndexedAccess, 3 Hours, 10,000 JPY.
kaonavi
1
310
マーケットプレイス版Oracle WebCenter Content For OCI
oracle4engineer
PRO
5
1.8k
Claude code Orchestra
ozakiomumkj
3
980
GoとSIMDとWasmの今。
askua
3
510
Oracle AI Database@AWS:サービス概要のご紹介
oracle4engineer
PRO
4
2.8k
Featured
See All Featured
How Fast Is Fast Enough? [PerfNow 2025]
tammyeverts
3
600
We Are The Robots
honzajavorek
0
240
実際に使うSQLの書き方 徹底解説 / pgcon21j-tutorial
soudai
PRO
201
75k
Design in an AI World
tapps
1
220
Getting science done with accelerated Python computing platforms
jacobtomlinson
2
220
Noah Learner - AI + Me: how we built a GSC Bulk Export data pipeline
techseoconnect
PRO
0
190
JavaScript: Past, Present, and Future - NDC Porto 2020
reverentgeek
52
6k
Side Projects
sachag
455
43k
Building a A Zero-Code AI SEO Workflow
portentint
PRO
0
550
State of Search Keynote: SEO is Dead Long Live SEO
ryanjones
0
200
The SEO Collaboration Effect
kristinabergwall1
1
480
How To Speak Unicorn (iThemes Webinar)
marktimemedia
1
480
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 やまのく
ご清聴 ありがとう ございました