{"id":25572,"date":"2022-11-15T13:29:00","date_gmt":"2022-11-15T20:29:00","guid":{"rendered":"https:\/\/cloudinary.com\/blog\/?p=25572"},"modified":"2022-11-15T14:28:46","modified_gmt":"2022-11-15T21:28:46","slug":"build-performant-engaging-experiences-in-next-js-with-next-cloudinary","status":"publish","type":"post","link":"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary","title":{"rendered":"Build Performant, Engaging Experiences in Next.js with Next Cloudinary"},"content":{"rendered":"\n<p>Building web and mobile apps requires teams to constantly analyze the requests being made and what can be done to avoid slow-loading pages which hurt engagement and make your visitors unhappy.<\/p>\n\n\n\n<p>Fortunately, there are tools like Next.js that allow those teams to build web apps with performance in mind.&nbsp; Which is great, but, where does a dev go for high-scale image delivery and management in those Next.js apps?<\/p>\n\n\n\n<h2 class=\"wp-block-heading\"><strong>Next Cloudinary<\/strong><\/h2>\n\n\n\n<p><a href=\"https:\/\/next-cloudinary.spacejelly.dev\/\">Next Cloudinary<\/a> gives developers first-class support for using Cloudinary in Next.js applications. Delivering images at scale with automatic optimization, on-the-fly transformations, and the ability to add drop-in uploading can now be done with the <a href=\"https:\/\/cloudinary.com\/documentation\/upload_widget\">Cloudinary Upload Widget<\/a>.<\/p>\n\n\n\n<figure class=\"wp-block-image size-large is-resized\"><img width=\"1024\" height=\"512\" data-public-id=\"nextjs1\/nextjs1.png\" loading=\"lazy\" decoding=\"async\" src=\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/w_1024,h_512,c_scale\/f_auto,q_auto\/v1667495180\/nextjs1\/nextjs1.png?_i=AA\" alt=\"Code snippet showing transforming woman with headphones into square image with text\" class=\"wp-post-25572 wp-image-25637\" data-format=\"png\" data-transformations=\"f_auto,q_auto\" data-version=\"1667495180\" data-seo=\"1\" srcset=\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667495180\/nextjs1\/nextjs1.png?_i=AA 1600w, https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667495180\/nextjs1\/nextjs1.png?_i=AA 300w, https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667495180\/nextjs1\/nextjs1.png?_i=AA 768w, https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667495180\/nextjs1\/nextjs1.png?_i=AA 1024w, https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667495180\/nextjs1\/nextjs1.png?_i=AA 1536w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><figcaption>Dynamically cropping and resizing with text overlays<\/figcaption><\/figure>\n\n\n\n<p>Using Next Cloudinary, you can feel confident you&#8217;re building performant experiences with images, letting Cloudinary do the hard work behind the scenes.<\/p>\n\n\n<div class='c-callout  c-callout--inline-title c-callout--note'><strong class='c-callout__title'>Note:<\/strong> <p>Next Cloudinary is a <a href=\"https:\/\/cloudinary.com\/documentation\/community_sdks\">community integration<\/a> supported by the Cloudinary Developer Relations team and the broader community through <a href=\"https:\/\/github.com\/colbyfayock\/next-cloudinary\">open source<\/a>.<\/p>\n<\/div>\n\n\n<h2 class=\"wp-block-heading\"><strong>How Next Cloudinary Works<\/strong><\/h2>\n\n\n\n<p>At its core, Next Cloudinary offers a <a href=\"https:\/\/next-cloudinary.spacejelly.dev\/components\/cldimage\/basic-usage\">CldImage<\/a> component that wraps and extends the <a href=\"https:\/\/nextjs.org\/docs\/api-reference\/next\/image\">Next.js Image<\/a> component, giving you the same developer experience you expect from Next.js, while providing the features and performance you love from Cloudinary.<\/p>\n\n\n\n<p>The component passes in a custom Loader function to the Image component, which uses the Image props to build Cloudinary URLs, along with allowing additional props to control any transformations like <a href=\"https:\/\/next-cloudinary.spacejelly.dev\/use-cases\/background-removal\">background removal<\/a>.<\/p>\n\n\n\n<p>We take the CldImage component further with <a href=\"https:\/\/next-cloudinary.spacejelly.dev\/components\/cldogimage\/basic-usage\">CldOgImage<\/a>, which generates an Open Graph Social Media Card using the same API as CldImage. It works by using the Next.js Head component to lift custom meta tags into the document&#8217;s &lt;head&gt;.<\/p>\n\n\n\n<figure class=\"wp-block-image size-large is-resized\"><img width=\"1024\" height=\"512\" data-public-id=\"nextjs2\/nextjs2.png\" loading=\"lazy\" decoding=\"async\" src=\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/w_1024,h_512,c_scale\/f_auto,q_auto\/v1667495203\/nextjs2\/nextjs2.png?_i=AA\" alt=\"Generating a social media card with Next Cloudinary and CldOgImage\" class=\"wp-post-25572 wp-image-25638\" data-format=\"png\" data-transformations=\"f_auto,q_auto\" data-version=\"1667495203\" data-seo=\"1\" srcset=\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667495203\/nextjs2\/nextjs2.png?_i=AA 1600w, https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667495203\/nextjs2\/nextjs2.png?_i=AA 300w, https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667495203\/nextjs2\/nextjs2.png?_i=AA 768w, https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667495203\/nextjs2\/nextjs2.png?_i=AA 1024w, https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667495203\/nextjs2\/nextjs2.png?_i=AA 1536w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><figcaption><a href=\"https:\/\/next-cloudinary.spacejelly.dev\/use-cases\/social-media-card\">Next Cloudinary Social Media Card<\/a><\/figcaption><\/figure>\n\n\n\n<p>Finally, to make uploading easy for everyone, the <a href=\"https:\/\/next-cloudinary.spacejelly.dev\/components\/clduploadbutton\/basic-usage\">CldUploadButton<\/a> and <a href=\"https:\/\/next-cloudinary.spacejelly.dev\/components\/clduploadwidget\/basic-usage\">CldUploadWidget<\/a> components use the existing Cloudinary Upload Widget, built with a friendly React API and Next.js tools like the <a href=\"https:\/\/nextjs.org\/docs\/api-reference\/next\/script\">Script<\/a> component.<\/p>\n\n\n\n<p>All this keeps you productive and helps to build a great experience for your visitors.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\"><strong>Using Next Cloudinary<\/strong><\/h2>\n\n\n\n<p>To get started, install Next Cloudinary with your favorite package manager:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-1\" data-shcb-language-name=\"Shell Session\" data-shcb-language-slug=\"shell\"><span><code class=\"hljs language-shell shcb-wrap-lines\">yarn add next-cloudinary\n<span class=\"hljs-meta\">#<\/span><span class=\"bash\"> or<\/span>\nnpm install next-cloudinary<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-1\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">Shell Session<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">shell<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>To ensure you&#8217;re delivering images from your Cloudinary account, add a new environment variable to your .env.local or CI:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-2\" data-shcb-language-name=\"Shell Session\" data-shcb-language-slug=\"shell\"><span><code class=\"hljs language-shell shcb-wrap-lines\">NEXT_PUBLIC_CLOUDINARY_CLOUD_NAME=\"&lt;Your Cloud Name&gt;\"<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-2\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">Shell Session<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">shell<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>Once ready, import the component that you wish to use, like the CldImage component, with:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-3\" data-shcb-language-name=\"JavaScript\" data-shcb-language-slug=\"javascript\"><span><code class=\"hljs language-javascript shcb-wrap-lines\"><span class=\"hljs-keyword\">import<\/span> { CldImage } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'next-cloudinary'<\/span>;<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-3\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">JavaScript<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">javascript<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<p>And drop it in your project:<\/p>\n\n\n<pre class=\"wp-block-code\" aria-describedby=\"shcb-language-4\" data-shcb-language-name=\"JavaScript\" data-shcb-language-slug=\"javascript\"><span><code class=\"hljs language-javascript shcb-wrap-lines\">&lt;CldImage\n  width=<span class=\"hljs-string\">\"600\"<\/span>\n  height=<span class=\"hljs-string\">\"600\"<\/span> \n  src=<span class=\"hljs-string\">\"&lt;PublicID&gt;\"<\/span>\n  alt=<span class=\"hljs-string\">\"My Image\"<\/span>\n\/&gt;<\/code><\/span><small class=\"shcb-language\" id=\"shcb-language-4\"><span class=\"shcb-language__label\">Code language:<\/span> <span class=\"shcb-language__name\">JavaScript<\/span> <span class=\"shcb-language__paren\">(<\/span><span class=\"shcb-language__slug\">javascript<\/span><span class=\"shcb-language__paren\">)<\/span><\/small><\/pre>\n\n\n<h2 class=\"wp-block-heading\"><strong>Learn More &amp; Get Started<\/strong><\/h2>\n\n\n\n<p>To learn more about what components, APIs, and features are available, head over to the <a href=\"https:\/\/next-cloudinary.spacejelly.dev\/\">Next Cloudinary Docs<\/a>.<br>For bugs, issues, or feature requests, find <a href=\"https:\/\/github.com\/colbyfayock\/next-cloudinary\">Next Cloudinary on GitHub<\/a>.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Building web and mobile apps requires teams to constantly analyze the requests being made and what can be done to avoid slow-loading pages which hurt engagement and make your visitors unhappy. Fortunately, there are tools like Next.js that allow those teams to build web apps with performance in mind.&nbsp; Which is great, but, where does [&hellip;]<\/p>\n","protected":false},"author":54,"featured_media":25643,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"_cloudinary_featured_overwrite":false,"footnotes":""},"categories":[1],"tags":[212],"class_list":["post-25572","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-uncategorized","tag-next-js"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v25.6 (Yoast SEO v26.9) - https:\/\/yoast.com\/product\/yoast-seo-premium-wordpress\/ -->\n<title>Build Performant, Engaging Experiences in Next.js with Next Cloudinary<\/title>\n<meta name=\"description\" content=\"Building web and mobile apps requires teams to constantly analyze the requests being made and what can be done to avoid slow-loading pages which hurt\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Build Performant, Engaging Experiences in Next.js with Next Cloudinary\" \/>\n<meta property=\"og:description\" content=\"Building web and mobile apps requires teams to constantly analyze the requests being made and what can be done to avoid slow-loading pages which hurt\" \/>\n<meta property=\"og:url\" content=\"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary\" \/>\n<meta property=\"og:site_name\" content=\"Cloudinary Blog\" \/>\n<meta property=\"article:published_time\" content=\"2022-11-15T20:29:00+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2022-11-15T21:28:46+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/v1667540784\/Cld_Blog_FeatImg_Nov2k22_NextJS\/Cld_Blog_FeatImg_Nov2k22_NextJS-png?_i=AA\" \/>\n\t<meta property=\"og:image:width\" content=\"2000\" \/>\n\t<meta property=\"og:image:height\" content=\"1100\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"NewsArticle\",\"@id\":\"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary#article\",\"isPartOf\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary\"},\"author\":{\"name\":\"\",\"@id\":\"\"},\"headline\":\"Build Performant, Engaging Experiences in Next.js with Next Cloudinary\",\"datePublished\":\"2022-11-15T20:29:00+00:00\",\"dateModified\":\"2022-11-15T21:28:46+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary\"},\"wordCount\":412,\"publisher\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/#organization\"},\"image\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary#primaryimage\"},\"thumbnailUrl\":\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667540784\/Cld_Blog_FeatImg_Nov2k22_NextJS\/Cld_Blog_FeatImg_Nov2k22_NextJS.png?_i=AA\",\"keywords\":[\"Next.js\"],\"inLanguage\":\"en-US\",\"copyrightYear\":\"2022\",\"copyrightHolder\":{\"@id\":\"https:\/\/cloudinary.com\/#organization\"}},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary\",\"url\":\"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary\",\"name\":\"Build Performant, Engaging Experiences in Next.js with Next Cloudinary\",\"isPartOf\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary#primaryimage\"},\"image\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary#primaryimage\"},\"thumbnailUrl\":\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667540784\/Cld_Blog_FeatImg_Nov2k22_NextJS\/Cld_Blog_FeatImg_Nov2k22_NextJS.png?_i=AA\",\"datePublished\":\"2022-11-15T20:29:00+00:00\",\"dateModified\":\"2022-11-15T21:28:46+00:00\",\"description\":\"Building web and mobile apps requires teams to constantly analyze the requests being made and what can be done to avoid slow-loading pages which hurt\",\"breadcrumb\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary#primaryimage\",\"url\":\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667540784\/Cld_Blog_FeatImg_Nov2k22_NextJS\/Cld_Blog_FeatImg_Nov2k22_NextJS.png?_i=AA\",\"contentUrl\":\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667540784\/Cld_Blog_FeatImg_Nov2k22_NextJS\/Cld_Blog_FeatImg_Nov2k22_NextJS.png?_i=AA\",\"width\":2000,\"height\":1100},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/cloudinary.com\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Build Performant, Engaging Experiences in Next.js with Next Cloudinary\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/cloudinary.com\/blog\/#website\",\"url\":\"https:\/\/cloudinary.com\/blog\/\",\"name\":\"Cloudinary Blog\",\"description\":\"\",\"publisher\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/cloudinary.com\/blog\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":\"Organization\",\"@id\":\"https:\/\/cloudinary.com\/blog\/#organization\",\"name\":\"Cloudinary Blog\",\"url\":\"https:\/\/cloudinary.com\/blog\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/cloudinary.com\/blog\/#\/schema\/logo\/image\/\",\"url\":\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1649718331\/Web_Assets\/blog\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877.png?_i=AA\",\"contentUrl\":\"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1649718331\/Web_Assets\/blog\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877.png?_i=AA\",\"width\":312,\"height\":60,\"caption\":\"Cloudinary Blog\"},\"image\":{\"@id\":\"https:\/\/cloudinary.com\/blog\/#\/schema\/logo\/image\/\"}},{\"@type\":\"Person\",\"@id\":\"\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"Build Performant, Engaging Experiences in Next.js with Next Cloudinary","description":"Building web and mobile apps requires teams to constantly analyze the requests being made and what can be done to avoid slow-loading pages which hurt","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary","og_locale":"en_US","og_type":"article","og_title":"Build Performant, Engaging Experiences in Next.js with Next Cloudinary","og_description":"Building web and mobile apps requires teams to constantly analyze the requests being made and what can be done to avoid slow-loading pages which hurt","og_url":"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary","og_site_name":"Cloudinary Blog","article_published_time":"2022-11-15T20:29:00+00:00","article_modified_time":"2022-11-15T21:28:46+00:00","og_image":[{"width":2000,"height":1100,"url":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/v1667540784\/Cld_Blog_FeatImg_Nov2k22_NextJS\/Cld_Blog_FeatImg_Nov2k22_NextJS-png?_i=AA","type":"image\/png"}],"twitter_card":"summary_large_image","schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"NewsArticle","@id":"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary#article","isPartOf":{"@id":"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary"},"author":{"name":"","@id":""},"headline":"Build Performant, Engaging Experiences in Next.js with Next Cloudinary","datePublished":"2022-11-15T20:29:00+00:00","dateModified":"2022-11-15T21:28:46+00:00","mainEntityOfPage":{"@id":"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary"},"wordCount":412,"publisher":{"@id":"https:\/\/cloudinary.com\/blog\/#organization"},"image":{"@id":"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary#primaryimage"},"thumbnailUrl":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667540784\/Cld_Blog_FeatImg_Nov2k22_NextJS\/Cld_Blog_FeatImg_Nov2k22_NextJS.png?_i=AA","keywords":["Next.js"],"inLanguage":"en-US","copyrightYear":"2022","copyrightHolder":{"@id":"https:\/\/cloudinary.com\/#organization"}},{"@type":"WebPage","@id":"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary","url":"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary","name":"Build Performant, Engaging Experiences in Next.js with Next Cloudinary","isPartOf":{"@id":"https:\/\/cloudinary.com\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary#primaryimage"},"image":{"@id":"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary#primaryimage"},"thumbnailUrl":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667540784\/Cld_Blog_FeatImg_Nov2k22_NextJS\/Cld_Blog_FeatImg_Nov2k22_NextJS.png?_i=AA","datePublished":"2022-11-15T20:29:00+00:00","dateModified":"2022-11-15T21:28:46+00:00","description":"Building web and mobile apps requires teams to constantly analyze the requests being made and what can be done to avoid slow-loading pages which hurt","breadcrumb":{"@id":"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary#primaryimage","url":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667540784\/Cld_Blog_FeatImg_Nov2k22_NextJS\/Cld_Blog_FeatImg_Nov2k22_NextJS.png?_i=AA","contentUrl":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667540784\/Cld_Blog_FeatImg_Nov2k22_NextJS\/Cld_Blog_FeatImg_Nov2k22_NextJS.png?_i=AA","width":2000,"height":1100},{"@type":"BreadcrumbList","@id":"https:\/\/cloudinary.com\/blog\/build-performant-engaging-experiences-in-next-js-with-next-cloudinary#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/cloudinary.com\/blog\/"},{"@type":"ListItem","position":2,"name":"Build Performant, Engaging Experiences in Next.js with Next Cloudinary"}]},{"@type":"WebSite","@id":"https:\/\/cloudinary.com\/blog\/#website","url":"https:\/\/cloudinary.com\/blog\/","name":"Cloudinary Blog","description":"","publisher":{"@id":"https:\/\/cloudinary.com\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/cloudinary.com\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Organization","@id":"https:\/\/cloudinary.com\/blog\/#organization","name":"Cloudinary Blog","url":"https:\/\/cloudinary.com\/blog\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/cloudinary.com\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1649718331\/Web_Assets\/blog\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877.png?_i=AA","contentUrl":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1649718331\/Web_Assets\/blog\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877\/cloudinary_logo_for_white_bg_1937437aa7_19374666c7_193742f877.png?_i=AA","width":312,"height":60,"caption":"Cloudinary Blog"},"image":{"@id":"https:\/\/cloudinary.com\/blog\/#\/schema\/logo\/image\/"}},{"@type":"Person","@id":""}]}},"jetpack_featured_media_url":"https:\/\/res.cloudinary.com\/cloudinary-marketing\/images\/f_auto,q_auto\/v1667540784\/Cld_Blog_FeatImg_Nov2k22_NextJS\/Cld_Blog_FeatImg_Nov2k22_NextJS.png?_i=AA","_links":{"self":[{"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/posts\/25572","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/users\/54"}],"replies":[{"embeddable":true,"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/comments?post=25572"}],"version-history":[{"count":9,"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/posts\/25572\/revisions"}],"predecessor-version":[{"id":25697,"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/posts\/25572\/revisions\/25697"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/media\/25643"}],"wp:attachment":[{"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/media?parent=25572"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/categories?post=25572"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/cloudinary.com\/blog\/wp-json\/wp\/v2\/tags?post=25572"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}