In this tutorial, we’ll show you how to create a textarea component in a Next.js application using the ShadCN UI library.
Before using a textarea in Next.js 13 with ShadCN UI, you need to install it with the command: npx shadcn-ui add textarea
.
npx shadcn-ui@latest add textarea
#or
npx shadcn-ui@latest add
1. Create a simple textarea in Next.js 13 using the ShadCN UI Textarea
component.
import { Textarea } from "@/components/ui/textarea"
export default function TextareaDemo() {
return <Textarea placeholder="Type your message here." />
}
data:image/s3,"s3://crabby-images/6f942/6f942f5e7e9eb4c6e2754db842ea2c6bbe68e194" alt="shadcn ui textarea"
2. Next.js with ShadCN UI textarea disabled.
import { Textarea } from "@/components/ui/textarea"
export default function TextareaDemo() {
return <Textarea placeholder="Type your message here." disabled />
}
3. Next.js with ShadCN UI textarea with a label.
import { Label } from "@/components/ui/label"
import { Textarea } from "@/components/ui/textarea"
export default function TextareaWithLabel() {
return (
<div className="grid w-full gap-1.5">
<Label htmlFor="message">Your message</Label>
<Textarea placeholder="Type your message here." id="message" />
</div>
)
}
data:image/s3,"s3://crabby-images/d43f2/d43f20d17551c9a030431567b5c2c25bca2d0984" alt="textarea with label"
4. Next.js with ShadCN UI textarea with a label and text.
import { Label } from "@/components/ui/label"
import { Textarea } from "@/components/ui/textarea"
export default function TextareaWithText() {
return (
<div className="grid w-full gap-1.5">
<Label htmlFor="message-2">Your Message</Label>
<Textarea placeholder="Type your message here." id="message-2" />
<p className="text-sm text-muted-foreground">
Your message will be copied to the support team.
</p>
</div>
)
}
data:image/s3,"s3://crabby-images/d5c3b/d5c3bc8d142a1e3b82e20a5409533cd21dd03259" alt="shadcn ui textarea with label and text"
5. Next.js with ShadCN UI textarea with a button.
import { Button } from "@/components/ui/button"
import { Textarea } from "@/components/ui/textarea"
export default function TextareaWithButton() {
return (
<div className="grid w-full gap-2">
<Textarea placeholder="Type your message here." />
<Button>Send message</Button>
</div>
)
}
data:image/s3,"s3://crabby-images/e6314/e63145d385486493040507144781042c10993bc3" alt="textarea with button"