[{"data":1,"prerenderedAt":133},["ShallowReactive",2],{"blog-tech":3},[4],{"id":5,"title":6,"body":7,"category":115,"date":116,"description":117,"draft":118,"extension":119,"meta":120,"navigation":121,"path":122,"seo":123,"stem":124,"tags":125,"thumbnail":129,"thumbnailAlt":130,"updatedAt":131,"__hash__":132},"blog\u002Fblog\u002Ftech\u002Fnuxt4-migration.md","Nuxt 4 への移行で学んだこと",{"type":8,"value":9,"toc":100},"minimark",[10,14,18,21,25,50,53,67,70,74,85,88,94,97],[11,12,13],"h2",{"id":13},"はじめに",[15,16,17],"p",{},"個人ブログのフロントを Nuxt 3 から Nuxt 4 に移行してみました。互換レイヤーが用意されているとはいえ、いくつか手を入れる箇所があったので、気づきを残しておきます。",[11,19,20],{"id":20},"主な変更点",[22,23,24],"h3",{"id":24},"ディレクトリ構成",[15,26,27,31,32,35,36,35,39,42,43,46,47,49],{},[28,29,30],"code",{},"app\u002F"," ディレクトリが標準になり、",[28,33,34],{},"pages\u002F","・",[28,37,38],{},"components\u002F",[28,40,41],{},"composables\u002F"," などはこの配下に置く構成が推奨になりました。既存プロジェクトは ",[28,44,45],{},"compatibilityVersion"," を切り替えるだけでも動きますが、新規ならフラットに ",[28,48,30],{}," 配下にまとめておくのが見通しがよさそうです。",[22,51,52],{"id":52},"データ取得",[15,54,55,58,59,62,63,66],{},[28,56,57],{},"useAsyncData"," や ",[28,60,61],{},"useFetch"," の挙動と型は基本的に同じですが、一部のオプションで挙動が整理されています。レンダー前に必要なデータは、引き続き ",[28,64,65],{},"await"," 付きで取りに行く形が安全です。",[11,68,69],{"id":69},"詰まったところ",[22,71,73],{"id":72},"nuxt-content-の差分","Nuxt Content の差分",[15,75,76,77,80,81,84],{},"Content v3 では Collection API が追加され、",[28,78,79],{},"queryCollection('blog')"," のように扱う形に変わっていました。",[28,82,83],{},"queryContent"," 系のクエリは自前のラッパーを書いていた箇所と整合が取れず、書き直しが必要でした。",[22,86,87],{"id":87},"型推論",[15,89,90,93],{},[28,91,92],{},"schema"," で frontmatter を定義していると、コレクションから取り出した値がきちんと型付けされて気持ちよく書けます。最初に schema をしっかり書いておくと、あとで楽でした。",[11,95,96],{"id":96},"やってみた感想",[15,98,99],{},"「動かなくなる」というよりは「整理されて素直になった」という印象の移行でした。必要な範囲だけ手を入れて、徐々にディレクトリ構成も新しい形に寄せていく予定です。",{"title":101,"searchDepth":102,"depth":102,"links":103},"",3,[104,106,110,114],{"id":13,"depth":105,"text":13},2,{"id":20,"depth":105,"text":20,"children":107},[108,109],{"id":24,"depth":102,"text":24},{"id":52,"depth":102,"text":52},{"id":69,"depth":105,"text":69,"children":111},[112,113],{"id":72,"depth":102,"text":73},{"id":87,"depth":102,"text":87},{"id":96,"depth":105,"text":96},"tech","2026-04-25","Nuxt 3 から Nuxt 4 へのマイグレーションで遭遇した変更点と、その対処法を整理します。",false,"md",{},true,"\u002Fblog\u002Ftech\u002Fnuxt4-migration",{"title":6,"description":117},"blog\u002Ftech\u002Fnuxt4-migration",[126,127,128],"Nuxt","Vue.js","Web開発","\u002Fimages\u002Fblog\u002Fnuxt4-migration\u002Fthumbnail.jpg","Nuxt 4 移行作業のイメージ","2026-04-28","a7nAmClA8PEzcXMh4jylI_Gwhv72OYLqF9TDIBQFvAw",1777432174843]