can nextjs render markdown as component to be used inside a react component ?
Answered
Asian black bear posted this in #help-forum
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Asian black bearOP
Just like the title I was wondering if it's possible to use MDX as a component inside the react component
Answered by iyxan23
7 Replies
Answer
data:image/s3,"s3://crabby-images/7d993/7d993971ecdc66d18f9a65a116e22a5c8002a05b" alt="Avatar"
or are you trying to render an mdx code right into an element or something?
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Asian black bearOP
I wanted to render an MDX inside a react element, not just rendering it as a page
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Asian black bearOP
something like
function Product({name,description,price,img}:{name: string, description: string, price:number,img:string}){
return (
<h1> {name} </h1>
<img src={img}/>
<MarkdownRender markdown={description}/>
<p> {price} </p>
)
}
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
@Asian black bear I wanted to render an MDX inside a react element, not just rendering it as a page
data:image/s3,"s3://crabby-images/93fe2/93fe2e3635c48b56e0d3be1ca90fbb4c21ddde31" alt="Avatar"
The set up guide above still helps. Just follow the guide and you can then import the mdx
import Welcome from '@/markdown/welcome.mdx'
export default function Page() {
return <Welcome />
}
data:image/s3,"s3://crabby-images/275c3/275c333dd9c41bfcb60b2ce71c8cd83abb8eb125" alt="Avatar"
Northeast Congo Lion
I use
Then where you need it,
If you have concerns about the markdown possibly having embedded HTML, you should sanitize the generated HTML using DOMPurify
marked
for this. Basically:const html_version = marked.parse(markdown_version);
Then where you need it,
<div dangerouslySetInnerHTML={{ __html: html_version }} />
If you have concerns about the markdown possibly having embedded HTML, you should sanitize the generated HTML using DOMPurify
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Asian black bearOP
thanks everyone for the help, I'll try to implement the suggestion...