Related Posts
It’s very easy to add typescript to a Next.js project. In this post, I will list out steps on how to do so.
First, let’s create a new Nextjs project
my-ts-app
# Create a directory with name `my-ts-app`
mkdir my-ts-app
# Change directory to `my-ts-app`
cd my-ts-app
# Initialize the directory as an npm project
npm init -y
# Install `next`, `react` and `react-dom` as dependencies
npm install next react react-dom
# Create a directory with name `pages`
mkdir pages
# Create a file with name `index.tsx` inside `pages` directory
touch pages/index.tsx
File Structure
data:image/s3,"s3://crabby-images/acd4e/acd4e046ed62fd78da7ddc267181953e255884e8" alt="notion image"
Your package.json file
data:image/s3,"s3://crabby-images/1c551/1c551eba0c3c20aade92b7daa8844701ed4281ff" alt="notion image"
Add the following scripts to your
package.json
"scripts": {
"dev": "next dev",
"build": "next build",
"start": "next start"
}
data:image/s3,"s3://crabby-images/dff71/dff71227dd7fa5057fd4555884dabd3ca1b809de" alt="notion image"
Screenshot 2020-08-11 at 9.25.46 AM.png
Add the following to your
pages/index.tsx
file// pages/index.tsx
function HomePage() {
return <div>Welcome to Next.js!</div>
}
export default HomePage
Now, let’s add typescript to the project.
# Create an empty `tsconfig.json` file
touch tsconfig.json
# Add `typescript`, `@types/react` and `@types/node` as devDependencies
npm install --save-dev typescript @types/react @types/node
That’s it. Next time you run
npm run dev
, tsconfig.json
will be auto-populated with recommended typescript config for Next.js.data:image/s3,"s3://crabby-images/8f3b0/8f3b092c2a0290875ce1f0862d6af7b5a6eda8f9" alt="notion image"
data:image/s3,"s3://crabby-images/0e4e3/0e4e30402c313120ab60184578bf732e98365075" alt="notion image"
Open localhost:3000 in your browser
data:image/s3,"s3://crabby-images/a348b/a348b725e3a0aa52f249d17b05958a76b6f1e63f" alt="notion image"
Now, you can add types to your project as you normally would to any typescript project.
data:image/s3,"s3://crabby-images/97914/97914d6aa4ca5d303585559c0dcb37359a22c2c6" alt="Bhanu Teja P"
Written by
24yo developer and blogger. I quit my software dev job to make it as an independent maker. I write about bootsrapping Feather.