Next js 11 is now released. There are seven improvements introduced with this release.
In this article, I will go through each change and discuss it in detail. If you are starting a new Next js project, follow the below steps to begin.
The package.json will have the updated Next js and React js versions.
{
"name": "nextjs",
"version": "0.1.0",
"private": true,
"scripts": {
"dev": "next dev",
"build": "next build",
"start": "next start"
},
"dependencies": {
"next": "11.0.1",
"react": "17.0.2",
"react-dom": "17.0.2",
}
}
You can upgrade an existing project by running
Make sure your package.json is updated with the latest Next js and React js versions.
Next.js 11 introduces some incompatible changes which should not affect the majority of users. These legacy features have been backward-compatible for years since v4.0. This ensures reduced bundle size and maintainability of the codebase. With Next.js 11, the minimum required React version has been updated to 17.0.2.
Performance, security, and accessibility are major aspects of today's application development and maintenance. That introduces an extra layer of complexity on top of already complicated technical and business logic. Site owners and developers are responsible for handling these things.
Conformance includes delivering optimized solutions and rules to support optimal loading, Core Web Vitals, security, and accessibility. That plays a major role in adopting to latest google update related to Core Web Vitals.
These additions free developers from the additional security and maintenance overhead and allow them to focus on implementing the business necessities.
Next js 11 supports ESLint out of the box. For those who don't know about ESLint, ESLint can statically analyze your code to find any problems. Most of the editors have ESLint is built into them. You can add ESLint by running
Make sure to upgrade your project to Next js 11 before running the ESLint command. That optimizes the loading speed and adds an in-memory config caching layer.
Next js 11 comes with a new implementation of Babel loader for webpack. That means no functional changes for software developers but an improved development experience.
The newly introduced Next.js Script Component allows developers to set the loading priority of scripts. The developer has control over the loading sequence of scripts based on priority. Usually, third-party scripts such as analytics and display ads tend to be heavy on loading performance and reduces the user experience significantly. The new Script tag offers three strategies to load your scripts.
The beforeInteractive strategy is for scripts that need to be fetched and executed before the page is interactive. Scripts for bot detection and consent management are some examples. These scripts are inserted into the initial HTML rendered by the server and run before self-bundled JavaScript is executed.
<Script src="https://example.com/static/consentscript.js" strategy="beforeInteractive"/>
<Script src={url} strategy="beforeInteractive"
onLoad={() => {
//load other scripts in sequence
}}/>
This strategy is for scripts that can wait until the page becomes interactive. Scripts used for tag managers and analytics are potential candidates for this strategy. These scripts are inserted on the client-side and will run after page hydration.
<Script src="https://www.googletagmanager.com/gtag/js?id=122" strategy="afterInteractive"/>
This strategy is for scripts that can wait to load during idle time. Potential candidates are chat support and social media widgets.
<Script src="https://www.googletagmanager.com/gtag/js?id=122" strategy="lazyOnload"/>
There are several improvements for the next/image component. These changes help enhance SEO by reducing layout shifts and creating a smoother visual experience.
Unlike in the previous version, the built-in Image component doesn't require explicit height and width declaration. This is applicable when importing the image as a source.
import Image from 'next/image'
import logo from '../public/logo.png'
export default function Home() {
return (
<Image src={logo} alt="Website logo" />
)
}
Next js 11 Image component now supports blur-up placeholders. That reduces the loading time by enhancing the transition from blank space to the image. That improves SEO for users with slower internet connections.
<Image src={logo} alt="Learnbestcoding Logo" placeholder="blur" />
For dynamic images, the Image component supports custom blurDataURL which accepts dynamic images reside in back end.
<Image
src="https://nextjs.org/static/images/learn.png"
blurDataURL=""
alt="Logo"
placeholder="blur"
/>
Next js 11 makes webpack 5 the default for all Next js applications. Existing applications with custom webpacks can be upgraded to webpack 5.
Converting your React js application to Next js is easier than ever. This conversion automatically adds necessary Next js app structures such as pages directory and moves CSS imports to the proper location. That also enables a Create React App compatibility mode in Next.js.
Next.js Live improves development speed and experience. Technologies such as ServiceWorker, WebAssembly, and ES Modules are utilized to bring a significant amount of development process into the web browser.