{"id":9352,"date":"2025-11-19T12:26:47","date_gmt":"2025-11-19T03:26:47","guid":{"rendered":"https:\/\/fastcoding.jp\/blog\/?p=9352"},"modified":"2025-11-19T12:26:54","modified_gmt":"2025-11-19T03:26:54","slug":"next-nuxt-image-optimization","status":"publish","type":"post","link":"https:\/\/fastcoding.jp\/blog\/all\/frontend\/next-nuxt-image-optimization\/","title":{"rendered":"\uff1c\u753b\u50cf\u8aad\u307f\u8fbc\u307f\u8ca0\u8377\u3092\u5fb9\u5e95\u7ba1\u7406\uff1eNext\/Nuxt Image\u306e\u6700\u9069\u5316"},"content":{"rendered":"<div class=\"the_content\">\n<p>\u3053\u3093\u306b\u3061\u306f\u3001\u682a\u5f0f\u4f1a\u793e\u30d5\u30a1\u30b9\u30c8\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\u306e\u30d5\u30eb\u30b9\u30bf\u30c3\u30af\u30a8\u30f3\u30b8\u30cb\u30a2\u3001\u72ec\u8eab\u8cb4\u65cfFire\u3067\u3059\u3002<\/p>\n\n\n\n<p>\u3064\u3044\u5148\u9031\u3001\u8da3\u5473\u306e\u30d0\u30a4\u30af\u30c4\u30fc\u30ea\u30f3\u30b0\u3067\u5c71\u9593\u90e8\u306b\u51fa\u304b\u3051\u305f\u6642\u306e\u3053\u3068\u3067\u3059\u3002\u4f11\u61a9\u304c\u3066\u3089\u9053\u306e\u99c5\u3067\u30b9\u30de\u30db\u3092\u958b\u304d\u3001\u8fd1\u304f\u306e\u89b3\u5149\u30b9\u30dd\u30c3\u30c8\u3092\u691c\u7d22\u3057\u3066\u3044\u305f\u306e\u3067\u3059\u304c\u3001\u753b\u50cf\u304c\u591a\u3044\u30b5\u30a4\u30c8\u304c\u306a\u304b\u306a\u304b\u8868\u793a\u3055\u308c\u305a\u3001\u30a4\u30e9\u30a4\u30e9\u3057\u305f\u7d4c\u9a13\u304c\u3042\u308a\u307e\u3057\u305f\u3002\u7279\u306b\u30e1\u30a4\u30f3\u30d3\u30b8\u30e5\u30a2\u30eb\u304c\u3044\u3064\u307e\u3067\u3082\u8aad\u307f\u8fbc\u307e\u308c\u306a\u3044\u3068\u3001\u300c\u3053\u306e\u30b5\u30a4\u30c8\u3001\u672c\u5f53\u306b\u898b\u308b\u4fa1\u5024\u304c\u3042\u308b\u306e\u304b?\u300d\u3068\u7591\u554f\u3092\u6301\u3063\u3066\u3057\u307e\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<p><small><em>\u30d6\u30ed\u30b0\u306e\u66f8\u304d\u51fa\u3057\u3092\u66f8\u304f\u306e\u3063\u3066\u672c\u5f53\u306b\u96e3\u3057\u3044\u306a\u3063\u3066\u601d\u3044\u307e\u3059\u3002\u3067\u3082\u5618\u306f\u66f8\u3044\u3066\u306a\u3044\u3067\u3059\u3088&#8230;\u672c\u5f53\u306b\u91cd\u305f\u3044\u30da\u30fc\u30b8\u3067\u3057\u305f\u3002<\/em><\/small><\/p>\n\n\n\n<p>Web\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e\u4e16\u754c\u3067\u306f\u3001\u3053\u306e\u300c\u30e1\u30a4\u30f3\u30b3\u30f3\u30c6\u30f3\u30c4\u304c\u8868\u793a\u3055\u308c\u308b\u307e\u3067\u306e\u6642\u9593\u300d\u3092LCP(Largest Contentful Paint)\u3068\u547c\u3073\u3001Google\u306e\u30b3\u30a2\u30a6\u30a7\u30d6\u30d0\u30a4\u30bf\u30eb\u306e\u91cd\u8981\u6307\u6a19\u306e\u4e00\u3064\u3068\u3057\u3066\u4f4d\u7f6e\u3065\u3051\u3089\u308c\u3066\u3044\u307e\u3059\u3002\u7279\u306bEC\u3001\u4e0d\u52d5\u7523\u3001\u30e1\u30c7\u30a3\u30a2\u30b5\u30a4\u30c8\u306a\u3069\u3001<strong>\u753b\u50cf\u304c\u4e3b\u5f79\u306e\u30b5\u30a4\u30c8<\/strong>\u3067\u306f\u3001LCP\u306e\u5927\u534a\u304c\u753b\u50cf\u306e\u8aad\u307f\u8fbc\u307f\u6642\u9593\u306b\u4f9d\u5b58\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u4eca\u56de\u306f\u3001Next.js\u3068Nuxt\u3068\u3044\u30462\u5927\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u306e\u753b\u50cf\u6700\u9069\u5316\u6a5f\u80fd\u3092\u4f7f\u3063\u3066\u3001<strong>LCP\u3092\u78ba\u5b9f\u306b\u77ed\u7e2e\u3057\u3001CLS\u3082\u6291\u5236\u3059\u308b\u5b9f\u88c5\u624b\u6cd5<\/strong>\u3092\u3001\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u30a8\u30f3\u30b8\u30cb\u30a2\u306e\u8996\u70b9\u304b\u3089\u8a73\u3057\u304f\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u753b\u50cf\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e\u73fe\u72b6\u3068\u8ab2\u984c<\/h2>\n\n\n\n<p>\u7279\u306bEC\u30b5\u30a4\u30c8\u3084\u4e0d\u52d5\u7523\u30dd\u30fc\u30bf\u30eb\u3001\u30e1\u30c7\u30a3\u30a2\u30b5\u30a4\u30c8\u3067\u306f\u3001<strong>\u5546\u54c1\u753b\u50cf\u3001\u7269\u4ef6\u5199\u771f\u3001\u8a18\u4e8b\u306e\u30a2\u30a4\u30ad\u30e3\u30c3\u30c1\u753b\u50cf<\/strong>\u304c\u30b3\u30f3\u30c6\u30f3\u30c4\u306e\u4e2d\u5fc3\u3067\u3059\u3002\u3057\u304b\u3057\u3001\u753b\u50cf\u306e\u6271\u3044\u65b9\u6b21\u7b2c\u3067\u30e6\u30fc\u30b6\u30fc\u4f53\u9a13\u306f\u5927\u304d\u304f\u5909\u308f\u308a\u307e\u3059\u3002\u305d\u3057\u3066\u591a\u304f\u306e\u30b5\u30a4\u30c8\u3067\u306f\uff08\u3044\u307e\u3060\u306b\u30fb\u30fb\u30fb\uff09\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u5358\u7d14\u306a\u5b9f\u88c5\u304c\u884c\u308f\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<p><strong>\u60aa\u3044\u4f8b: \u5f93\u6765\u306e\uff08HTML\u305d\u306e\u307e\u307e\uff09\u5b9f\u88c5<\/strong><\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;img src=\"\/images\/product-large.jpg\" alt=\"\u5546\u54c1\u753b\u50cf\" \/&gt;<\/code><\/pre>\n\n\n\n<p>\u5358\u306bimg\u30bf\u30b0\u3092\u66f8\u304f\u3060\u3051\u3067\u753b\u50cf\u304c\u51fa\u308b\u304b\u3089HTML\u306f\u3059\u3054\u3044\u3093\u3067\u3059\u304c\u3001\u3053\u306e\u5b9f\u88c5\u306f\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e\u554f\u984c\u304c\u3042\u308a\u307e\u3059\u3002\u305f\u3068\u3048\u3070\u3001<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u89e3\u50cf\u5ea6\u306e\u6700\u9069\u5316\u304c\u3055\u308c\u3066\u3044\u306a\u3044<\/strong>: \u30c7\u30b9\u30af\u30c8\u30c3\u30d7\u3082\u30e2\u30d0\u30a4\u30eb\u3082\u540c\u3058\u5927\u304d\u306a\u753b\u50cf\u3092\u914d\u4fe1<\/li>\n\n\n\n<li><strong>\u512a\u5148\u5ea6\u5236\u5fa1\u304c\u306a\u3044<\/strong>: \u3059\u3079\u3066\u306e\u753b\u50cf\u304c\u540c\u3058\u512a\u5148\u5ea6\u3067\u8aad\u307f\u8fbc\u307e\u308c\u308b<\/li>\n\n\n\n<li><strong>\u30ec\u30a4\u30a2\u30a6\u30c8\u30b7\u30d5\u30c8\u304c\u767a\u751f<\/strong>: \u753b\u50cf\u304c\u8aad\u307f\u8fbc\u307e\u308c\u305f\u77ac\u9593\u306b\u30ec\u30a4\u30a2\u30a6\u30c8\u304c\u305a\u308c\u308b(CLS\u60aa\u5316)<\/li>\n\n\n\n<li><strong>\u5e2f\u57df\u306e\u7121\u99c4\u9063\u3044<\/strong>: \u30e2\u30d0\u30a4\u30eb\u74b0\u5883\u3067\u4e0d\u5fc5\u8981\u306b\u5927\u304d\u306a\u753b\u50cf\u3092\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9<\/li>\n<\/ul>\n\n\n\n<p>\u5b9f\u969b\u306b\u79c1\u305f\u3061\u304c\u904b\u7528\u3092\u62c5\u5f53\u3057\u3066\u3044\u308b\u3068\u3042\u308bEC\u30b5\u30a4\u30c8\u3067\u306f\u3001\u5f53\u521d\u3001\u5546\u54c1\u4e00\u89a7\u30da\u30fc\u30b8\u306eLCP\u304c4.2\u79d2\u306b\u3082\u9054\u3057\u3066\u3044\u307e\u3057\u305f\u3002\u3053\u308c\u306fGoogle\u306e\u63a8\u5968\u5024(2.5\u79d2\u4ee5\u4e0b)\u3092\u5927\u304d\u304f\u4e0a\u56de\u308b\u6570\u5024\u3067\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Next.js\/Nuxt\u306e\u753b\u50cf\u6700\u9069\u5316\u6a5f\u80fd<\/h2>\n\n\n\n<p>Next.js\u3068Nuxt\u306b\u306f\u3001\u305d\u308c\u305e\u308c\u5f37\u529b\u306a\u753b\u50cf\u6700\u9069\u5316\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u63d0\u4f9b\u3057\u3066\u3044\u307e\u3059\u3002\u5177\u4f53\u7684\u306b\u306f<strong>srcset\u3001fetchpriority\u3001\u5148\u8aad\u307f\u3001\u30a2\u30b9\u30da\u30af\u30c8\u6bd4\u5236\u5fa1<\/strong>\u3092\u81ea\u52d5\u7684\u306b\u3001\u3042\u308b\u3044\u306f\u7c21\u5358\u306b\u5b9f\u88c5\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">Next.js Image\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306b\u3088\u308b\u81ea\u52d5\u6700\u9069\u5316<\/h3>\n\n\n\n<p>Next.js\u306e<code>&lt;Image><\/code>\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u4f7f\u3048\u3070\u3001\u753b\u50cf\u3092\u3044\u308d\u3044\u308d\u3068\u81ea\u52d5\u7684\u306b\u6700\u9069\u5316\u3057\u3066\u304f\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<p><strong>\u826f\u3044\u4f8b: Next.js Image\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u57fa\u672c\u5b9f\u88c5<\/strong><\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\nimport Image from &#039;next\/image&#039;\n\nexport default function ProductCard({ product }) {\n  return (\n    &lt;div className=&quot;product-card&quot;&gt;\n      &lt;Image\n        src={product.imageUrl}\n        alt={product.name}\n        width={800}\n        height={600}\n        sizes=&quot;(max-width: 640px) 100vw, (max-width: 1024px) 50vw, 800px&quot;\n        quality={85}\n      \/&gt;\n    &lt;\/div&gt;\n  )\n}\n<\/pre><\/div>\n\n\n<p><strong>\u81ea\u52d5\u7684\u306b\u6700\u9069\u5316\u3055\u308c\u308b\u3053\u3068:<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>srcset\u306e\u81ea\u52d5\u751f\u6210<\/strong>: \u30c7\u30d0\u30a4\u30b9\u306b\u5fdc\u3058\u305f\u8907\u6570\u30b5\u30a4\u30ba\u306e\u753b\u50cf\u3092\u81ea\u52d5\u751f\u6210\uff08\u3053\u308c\u304c\u4e00\u756a\u4fbf\u5229\uff09<\/li>\n\n\n\n<li><strong>WebP\/AVIF\u5909\u63db<\/strong>: \u30d6\u30e9\u30a6\u30b6\u30b5\u30dd\u30fc\u30c8\u306b\u5fdc\u3058\u3066\u6700\u9069\u306a\u30d5\u30a9\u30fc\u30de\u30c3\u30c8\u306b\u81ea\u52d5\u5909\u63db<\/li>\n\n\n\n<li><strong>\u9045\u5ef6\u8aad\u307f\u8fbc\u307f<\/strong>: \u30c7\u30d5\u30a9\u30eb\u30c8\u3067\u30d3\u30e5\u30fc\u30dd\u30fc\u30c8\u5916\u306e\u753b\u50cf\u306f\u9045\u5ef6\u8aad\u307f\u8fbc\u307f<\/li>\n\n\n\n<li><strong>CLS\u9632\u6b62<\/strong>: width\/height\u306b\u3088\u308b\u9818\u57df\u78ba\u4fdd\u3067\u81ea\u52d5\u7684\u306bCLS\u6291\u5236<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\">Next.js Image \u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e fetchpriority \u3067 LCP \u6700\u9069\u5316<\/h4>\n\n\n\n<p>\u81ea\u52d5\u7684\u306b\u9045\u5ef6\u8aad\u307f\u8fbc\u307f\u3055\u308c\u308b\u3068\u554f\u984c\u304c\u8d77\u304d\u308b\u5834\u5408\u304c\u3042\u308a\u307e\u3059\u306d\u3002\u305f\u3068\u3048\u3070\u30da\u30fc\u30b8\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3\u3067\u4f7f\u3063\u3066\u3044\u305f\u308a\u3001\u30de\u30a6\u30b9\u306e\u30db\u30d0\u30fc\u3084\u30ad\u30fc\u64cd\u4f5c\u3067\u8868\u793a\u3055\u308c\u308b\u3088\u3046\u306a\u8981\u7d20\u3067\u3059\u3002\u3053\u3046\u3044\u3063\u305f\u8981\u7d20\u306b\u3064\u3044\u3066\u306fp<code>riority<\/code>\u5c5e\u6027\u3092\u6307\u5b9a\u3057\u307e\u3059\u3002\u3053\u308c\u306b\u3088\u308a<code>fetchpriority=\"high\"<\/code>\u304c\u81ea\u52d5\u8a2d\u5b9a\u3055\u308c\u3001\u9045\u5ef6\u8aad\u307f\u8fbc\u307f\u3082\u30b9\u30ad\u30c3\u30d7\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<p><strong>\u826f\u3044\u4f8b: LCP\u8981\u7d20\u3078\u306e priority \u6307\u5b9a<\/strong><\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\nimport Image from &#039;next\/image&#039;\n\nexport default function Hero() {\n  return (\n    &lt;div className=&quot;hero&quot;&gt;\n      &lt;Image\n        src=&quot;\/images\/hero.jpg&quot;\n        alt=&quot;\u30e1\u30a4\u30f3\u30d3\u30b8\u30e5\u30a2\u30eb&quot;\n        width={1920}\n        height={1080}\n        sizes=&quot;100vw&quot;\n        priority  \/\/ \u2190 fetchpriority=&quot;high&quot; &amp; \u9045\u5ef6\u8aad\u307f\u8fbc\u307f\u7121\u52b9\u5316\n        quality={90}\n      \/&gt;\n    &lt;\/div&gt;\n  )\n}\n<\/pre><\/div>\n\n\n<p>\u305f\u3060\u3057\u3001\u904e\u5270\u306b\u3053\u308c\u3092\u4f7f\u3046\u306e\u306f\u7d50\u5c40\u610f\u5473\u304c\u306a\u304f\u306a\u308a\u307e\u3059\u306e\u3067\uff08\u753b\u50cf\u304c\u307e\u305f\u5373\u6642\u8aad\u307f\u8fbc\u307f\u306b\u306a\u308b\u3060\u3051\u306a\u306e\u3067\uff09\u753b\u50cf\u306e\u89e3\u50cf\u5ea6\u306b\u3082\u3088\u308a\u307e\u3059\u304c\u3001\uff11\u30da\u30fc\u30b8\u306b\u301c\uff13\u500b\u3050\u3089\u3044\u3001\u3068\u3044\u3046\u7a0b\u5ea6\u306e\u3001\u672c\u5f53\u306b\u300c\u512a\u5148\u300d\u3059\u308b\u753b\u50cf\u3068\u3057\u3066\u5b9a\u7fa9\u3057\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\">Next.js Image &#8211; preload \u3067\u306e\u5148\u8aad\u307f\u6700\u9069\u5316<\/h4>\n\n\n\n<p>Next.js 15\u4ee5\u964d\u3067\u306f\u3001<code>&lt;link rel=\"preload\"&gt;<\/code>\u3082\u81ea\u52d5\u7684\u306b\u51fa\u529b\u3055\u308c\u307e\u3059\u3002\u3055\u3089\u306b\u7d30\u304b\u304f\u5236\u5fa1\u3057\u305f\u3044\u5834\u5408\u306f\u3001<code>next\/head<\/code>\u3067\u660e\u793a\u7684\u306b\u8a2d\u5b9a\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p><strong>\u826f\u3044\u4f8b: \u624b\u52d5preload\u8a2d\u5b9a(Next.js)<\/strong><\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\nimport Head from &#039;next\/head&#039;\nimport Image from &#039;next\/image&#039;\n\nexport default function ProductPage({ product }) {\n  return (\n    &lt;&gt;\n      &lt;Head&gt;\n        &lt;link\n          rel=&quot;preload&quot;\n          as=&quot;image&quot;\n          href={product.heroImage}\n          imageSrcSet={`${product.heroImage}?w=640 640w, ${product.heroImage}?w=1200 1200w`}\n          imageSizes=&quot;100vw&quot;\n        \/&gt;\n      &lt;\/Head&gt;\n      &lt;Image\n        src={product.heroImage}\n        alt={product.name}\n        width={1200}\n        height={800}\n        priority\n      \/&gt;\n    &lt;\/&gt;\n  )\n}\n<\/pre><\/div>\n\n\n<h3 class=\"wp-block-heading\">Nuxt Image \u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306b\u3088\u308b\u6700\u9069\u5316<\/h3>\n\n\n\n<p>Nuxt\u3067\u306f<code>@nuxt\/image<\/code>\u30e2\u30b8\u30e5\u30fc\u30eb\u3092\u4f7f\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<p><strong>\u826f\u3044\u4f8b: Nuxt Image\u57fa\u672c\u5b9f\u88c5<\/strong><\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\n&lt;template&gt;\n  &lt;div class=&quot;product-card&quot;&gt;\n    &lt;NuxtImg\n      :src=&quot;product.imageUrl&quot;\n      :alt=&quot;product.name&quot;\n      width=&quot;800&quot;\n      height=&quot;600&quot;\n      sizes=&quot;sm:100vw md:50vw lg:800px&quot;\n      :quality=&quot;85&quot;\n    \/&gt;\n  &lt;\/div&gt;\n&lt;\/template&gt;\n\n&lt;script setup&gt;\nconst props = defineProps({\n  product: Object\n})\n&lt;\/script&gt;\n<\/pre><\/div>\n\n\n<p><strong>Nuxt\u7248 Image\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u7279\u5fb4:<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u81ea\u52d5\u7684\u306asrcset\u751f\u6210<\/strong>: \u30b5\u30a4\u30ba\u306b\u5fdc\u3058\u305f\u8907\u6570\u753b\u50cf\u3092\u81ea\u52d5\u751f\u6210<\/li>\n\n\n\n<li><strong>\u30d7\u30ed\u30d0\u30a4\u30c0\u30fc\u5bfe\u5fdc<\/strong>: Cloudinary\u3001Imgix\u3001Vercel\u306a\u3069\u4e3b\u8981CDN\u306b\u5bfe\u5fdc<\/li>\n\n\n\n<li><strong>\u9045\u5ef6\u8aad\u307f\u8fbc\u307f<\/strong>: \u30c7\u30d5\u30a9\u30eb\u30c8\u3067<code>loading=\"lazy\"<\/code><\/li>\n\n\n\n<li><strong>\u30d7\u30ec\u30fc\u30b9\u30db\u30eb\u30c0\u30fc<\/strong>: \u307c\u304b\u3057\u753b\u50cf\u3084\u8272\u3067\u8aad\u307f\u8fbc\u307f\u4e2d\u3092\u8868\u73fe<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\">Nuxt Image \u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e fetchpriority \u3068 preload<\/h4>\n\n\n\n<p>Nuxt\u3067\u3082\u3001LCP\u8981\u7d20\u306b\u306f<code>preload<\/code>\u3068fetchpriority\u3092\u8a2d\u5b9a\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p><strong>\u826f\u3044\u4f8b: Nuxt Image\u3067\u306e\u512a\u5148\u8aad\u307f\u8fbc\u307f<\/strong><\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\n&lt;template&gt;\n  &lt;div class=&quot;hero&quot;&gt;\n    &lt;NuxtImg\n      src=&quot;\/images\/hero.jpg&quot;\n      alt=&quot;\u30e1\u30a4\u30f3\u30d3\u30b8\u30e5\u30a2\u30eb&quot;\n      width=&quot;1920&quot;\n      height=&quot;1080&quot;\n      sizes=&quot;100vw&quot;\n      preload  \n      fetchpriority=&quot;high&quot;\n      :quality=&quot;90&quot;\n    \/&gt;\n  &lt;\/div&gt;\n&lt;\/template&gt;\n<\/pre><\/div>\n\n\n<p><strong>nuxt.config.ts \u3067preload\u8a2d\u5b9a:<\/strong><\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\nexport default defineNuxtConfig({\n  image: {\n    preload: {\n      formats: &#x5B;&#039;webp&#039;, &#039;avif&#039;]\n    }\n  }\n})\n<\/pre><\/div>\n\n\n<h2 class=\"wp-block-heading\">\u5b9f\u969b\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306e\u52b9\u679c<\/h2>\n\n\n\n<p>\u5f0a\u793e\u3067\u62c5\u5f53\u3057\u3066\u3044\u308b\u304a\u5ba2\u69d8\u306eEC\u30b5\u30a4\u30c8\u306e\u5546\u54c1\u4e00\u89a7\u30da\u30fc\u30b8\u3067\u3001Next.js Image\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u5c0e\u5165\u3057\u305f\u3068\u3053\u308d\u3001\u4ee5\u4e0b\u306e\u6539\u5584\u304c\u5f97\u3089\u308c\u307e\u3057\u305f\u3002<\/p>\n\n\n\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><thead><tr><th>\u6307\u6a19<\/th><th>\u6539\u5584\u524d<\/th><th>\u6539\u5584\u5f8c<\/th><th>\u6539\u5584\u7387<\/th><\/tr><\/thead><tbody><tr><td><strong>LCP<\/strong><\/td><td>4.2\u79d2<\/td><td>1.8\u79d2<\/td><td><strong>57%\u6539\u5584<\/strong><\/td><\/tr><tr><td><strong>CLS<\/strong><\/td><td>0.25<\/td><td>0.05<\/td><td><strong>80%\u6539\u5584<\/strong><\/td><\/tr><tr><td><strong>\u8ee2\u9001\u91cf(\u30e2\u30d0\u30a4\u30eb)<\/strong><\/td><td>3.2MB<\/td><td>1.1MB<\/td><td><strong>66%\u524a\u6e1b<\/strong><\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<h2 class=\"wp-block-heading\">\u5b9f\u88c5\u6642\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/h2>\n\n\n\n<p>\u57fa\u672c\u7684\u306b\u306f\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092\u4f7f\u3046\u3060\u3051\u3067\u6539\u5584\u3055\u308c\u308b\u306e\u3067\u3059\u304c\u3001\u4f7f\u3046\u6642\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u306f\u3053\u3046\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<p><strong>1. priority \u306f LCP \u8981\u7d20\u306e\u307f<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30d2\u30fc\u30ed\u30fc\u753b\u50cf\u3001\u30d5\u30a1\u30fc\u30b9\u30c8\u30d3\u30e5\u30fc\u306e\u4e3b\u8981\u753b\u50cf\u306e\u307f\u306b\u4f7f\u7528<\/li>\n\n\n\n<li>1\u30da\u30fc\u30b8\u3042\u305f\u308a1-2\u500b\u307e\u3067<\/li>\n<\/ul>\n\n\n\n<p><strong>2. sizes \u5c5e\u6027\u3092\u9069\u5207\u306b\u8a2d\u5b9a<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u30d3\u30e5\u30fc\u30dd\u30fc\u30c8\u5e45\u306b\u5fdc\u3058\u305f\u5b9f\u969b\u306e\u8868\u793a\u30b5\u30a4\u30ba\u3092\u6307\u5b9a<\/li>\n\n\n\n<li>\u30e2\u30d0\u30a4\u30eb\u3001\u30bf\u30d6\u30ec\u30c3\u30c8\u3001\u30c7\u30b9\u30af\u30c8\u30c3\u30d7\u3067\u7570\u306a\u308b\u5834\u5408\u306f\u7d30\u304b\u304f\u8a2d\u5b9a<\/li>\n<\/ul>\n\n\n\n<p><strong>3. quality \u306f\u7528\u9014\u306b\u5fdc\u3058\u3066\u8abf\u6574<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u5546\u54c1\u753b\u50cf\u30fb\u7269\u4ef6\u5199\u771f: 85-90<\/li>\n\n\n\n<li>\u80cc\u666f\u753b\u50cf: 75-80<\/li>\n\n\n\n<li>\u30a2\u30a4\u30b3\u30f3\u30fbUI\u753b\u50cf: 90-95<\/li>\n<\/ul>\n\n\n\n<p><strong>4. CDN\u30fb\u753b\u50cf\u30d7\u30ed\u30d0\u30a4\u30c0\u30fc\u306e\u6d3b\u7528<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Next.js: Vercel Image Optimization\u3001Cloudinary<\/li>\n\n\n\n<li>Nuxt: Cloudinary\u3001Imgix\u3001ImageKit<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">\u3088\u304f\u3042\u308b\u843d\u3068\u3057\u7a74<\/h3>\n\n\n\n<p><strong>\u904e\u5270\u306apreload\u30fbpriority<\/strong>\uff1a\u5168\u3066\u306e\u753b\u50cf\u306b<code>priority<\/code>\u3092\u6307\u5b9a\u3059\u308b\u3068\u3001\u30d6\u30e9\u30a6\u30b6\u304c\u3069\u308c\u3092\u512a\u5148\u3059\u3079\u304d\u304b\u5224\u65ad\u3067\u304d\u305a\u3001\u9006\u306b\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u304c\u60aa\u5316\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<p><strong>width\/height\u306e\u672a\u6307\u5b9a<\/strong>\uff1a\u30a2\u30b9\u30da\u30af\u30c8\u6bd4\u304c\u4e0d\u660e\u3060\u3068\u3001\u753b\u50cf\u8aad\u307f\u8fbc\u307f\u6642\u306b\u30ec\u30a4\u30a2\u30a6\u30c8\u30b7\u30d5\u30c8\u304c\u767a\u751f\u3057CLS\u304c\u60aa\u5316\u3057\u307e\u3059\u3002\u5fc5\u305awidth\/height\u3092\u6307\u5b9a\u3057\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<p><strong>\u30e2\u30d0\u30a4\u30eb\u3067\u9ad8\u753b\u8cea\u3059\u304e\u308b\u8a2d\u5b9a<\/strong>\uff1a<code>quality={95}<\/code>\u306a\u3069\u9ad8\u753b\u8cea\u8a2d\u5b9a\u3092\u30e2\u30d0\u30a4\u30eb\u3067\u3082\u4f7f\u3046\u3068\u3001\u8ee2\u9001\u91cf\u304c\u5897\u3048LCP\u304c\u60aa\u5316\u3057\u307e\u3059\u3002\u7528\u9014\u306b\u5fdc\u3058\u3066\u8abf\u6574\u3057\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<p>\u305d\u3057\u3066\u3042\u308a\u304c\u3061\u306a\u306e\u304c\u300c\u4f7f\u3044\u3059\u304e\u3066\u3057\u307e\u3046\u300d\u3068\u3044\u3046\u554f\u984c\u3067\u3059\u3002\u7279\u306b\u753b\u8cea\u8a2d\u5b9a\u306b\u3064\u3044\u3066\u306f\u3001\u6bce\u56de\u304a\u5ba2\u69d8\u3068\uff08\u4e3b\u306b\u30c7\u30b6\u30a4\u30ca\u69d8\u3068\uff09\u8b70\u8ad6\u306b\u306a\u308a\u307e\u3059\u304c\u3001\u30ec\u30c6\u30a3\u30fc\u30ca\u30c7\u30a3\u30b9\u30d7\u30ec\u30a4\u3092\u610f\u8b58\u3057\u3059\u304e\u3066\u753b\u8cea\u3092\u4e0a\u3052\u308b\u3053\u3068\u3067\u3001\u30da\u30fc\u30b8\u5168\u4f53\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306f\u843d\u3061\u308b\u3053\u3068\u306b\u306a\u308a\u307e\u3059\u306e\u3067\u3001\u7d50\u679c\u7684\u306b\u96e2\u8131\u3092\u5897\u3084\u3059\u3053\u3068\u306b\u306a\u308a\u307e\u3059\u3002\u898b\u305f\u76ee\u3084\u30c7\u30b6\u30a4\u30f3\u3068\u3001\u8868\u793a\u901f\u5ea6\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306f\u3001\u76f8\u53cd\u3059\u308b\u6642\u304c\u591a\u3044\u306e\u3067\u6ce8\u610f\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u3055\u304f\u3063\u3068\u753b\u50cf\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3067\u5bfe\u5fdc\u3057\u3066\u3057\u307e\u3044\u307e\u3057\u3087\u3046<\/h2>\n\n\n\n<p>\u753b\u50cf\u4e3b\u5c0e\u306eWeb\u30b5\u30a4\u30c8\u3067\u306f\u3001Next.js\u3084Nuxt\u306e\u753b\u50cf\u6700\u9069\u5316\u6a5f\u80fd\u3092\u6d3b\u7528\u3059\u308b\u3053\u3068\u3067\u3001HTML\u30d9\u30fc\u30b9\u306e\u624b\u52d5\u5b9f\u88c5\u3088\u308a\u3082<strong>\u5727\u5012\u7684\u306b\u7c21\u5358\u304b\u3064\u52b9\u679c\u7684<\/strong>\u306bLCP\u3068CLS\u3092\u6539\u5584\u3067\u304d\u307e\u3059\u3002\u62bc\u3055\u3048\u3066\u304a\u304d\u305f\u3044\u30dd\u30a4\u30f3\u30c8\u306f\u4ee5\u4e0b\u306e3\u3064\u3067\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>Next.js\/Nuxt Image\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3067\u81ea\u52d5\u6700\u9069\u5316<\/strong>: srcset\u3001WebP\/AVIF\u5909\u63db\u3001\u9045\u5ef6\u8aad\u307f\u8fbc\u307f\u3092\u81ea\u52d5\u5316<\/li>\n\n\n\n<li><strong>priority\u3067LCP\u8981\u7d20\u3092\u512a\u5148\u8aad\u307f\u8fbc\u307f<\/strong>: \u30d2\u30fc\u30ed\u30fc\u753b\u50cf\u3084\u30d5\u30a1\u30fc\u30b9\u30c8\u30d3\u30e5\u30fc\u753b\u50cf\u306b\u9650\u5b9a<\/li>\n\n\n\n<li><strong>width\/height\u6307\u5b9a\u3067CLS\u6291\u5236<\/strong>: \u30a2\u30b9\u30da\u30af\u30c8\u6bd4\u3092\u4fdd\u6301\u3057\u3001\u30ec\u30a4\u30a2\u30a6\u30c8\u30b7\u30d5\u30c8\u3092\u9632\u6b62<\/li>\n<\/ul>\n\n\n\n<p>\u5b9f\u969b\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u306f\u3001LCP\u304c57%\u6539\u5584\u3001CLS\u304c80%\u6539\u5584\u3001\u30e2\u30d0\u30a4\u30eb\u8ee2\u9001\u91cf\u304c66%\u524a\u6e1b\u3068\u3044\u3046\u7d50\u679c\u304c\u5f97\u3089\u308c\u307e\u3057\u305f\u3002<\/p>\n\n\n\n<p>\u682a\u5f0f\u4f1a\u793e\u30d5\u30a1\u30b9\u30c8\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\u3067\u306f\u3001\u3053\u3046\u3044\u3063\u305fNext.js\/Nuxt\u3092\u6d3b\u7528\u3057\u305f\u753b\u50cf\u6700\u9069\u5316\u3084LCP\u6539\u5584\u306e\u5b9f\u88c5\u30b5\u30dd\u30fc\u30c8\u3092\u884c\u3063\u3066\u3044\u307e\u3059\u3002EC\u3001\u4e0d\u52d5\u7523\u3001\u30e1\u30c7\u30a3\u30a2\u30b5\u30a4\u30c8\u306a\u3069\u3001\u753b\u50cf\u304c\u591a\u3044\u30b5\u30a4\u30c8\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u6539\u5584\u306b\u304a\u56f0\u308a\u306e\u969b\u306f\u3001\u305c\u3072<a href=\"https:\/\/fastcoding.jp\/contact\/?ad2=blog\" target=\"_blank\" rel=\"noopener\" title=\"\">\u304a\u554f\u3044\u5408\u308f\u305b\u30d5\u30a9\u30fc\u30e0<\/a>\u304b\u3089\u3054\u76f8\u8ac7\u304f\u3060\u3055\u3044\u3002<\/p>\n<\/div>","protected":false},"excerpt":{"rendered":"<p>Next.js\u3068Nuxt\u306e\u753b\u50cf\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3067LCP\u309257%\u6539\u5584\u3057\u305f\u5b9f\u88c5\u65b9\u6cd5\u3002fetchpriority\u3068preload\u3092\u6d3b\u7528\u3057\u3001EC\u30fb\u4e0d\u52d5\u7523\u30fb\u30e1\u30c7\u30a3\u30a2\u30b5\u30a4\u30c8\u306e\u753b\u50cf\u8aad\u307f\u8fbc\u307f\u3092\u6700\u9069\u5316\u3002CLS 80%\u6539\u5584\u3001\u8ee2\u9001\u91cf66%\u524a\u6e1b\u306e\u5b9f\u7e3e\u3002\u30b3\u30fc\u30c9\u4f8b\u4ed8\u304d\u5b9f\u8df5\u30ac\u30a4\u30c9\u3002<\/p>\n","protected":false},"author":20,"featured_media":9382,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":"","jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":true,"jetpack_social_options":{"image_generator_settings":{"template":"highway","default_image_id":0,"enabled":false},"version":2}},"categories":[13],"tags":[298,22,694,693],"class_list":["post-9352","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-frontend","tag-core-web-vitals","tag-javascript","tag-next-js","tag-693"],"acf":[],"aioseo_notices":[],"jetpack_publicize_connections":[],"jetpack_featured_media_url":"https:\/\/fastcoding.jp\/blog\/wp-content\/uploads\/2025\/11\/222bb65f54b53e35f01ef10bc3653957.png","jetpack_sharing_enabled":true,"amp_enabled":true,"_links":{"self":[{"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/posts\/9352","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/users\/20"}],"replies":[{"embeddable":true,"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/comments?post=9352"}],"version-history":[{"count":3,"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/posts\/9352\/revisions"}],"predecessor-version":[{"id":9384,"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/posts\/9352\/revisions\/9384"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/media\/9382"}],"wp:attachment":[{"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/media?parent=9352"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/categories?post=9352"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/tags?post=9352"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}