Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kyoncy/react-markdown-heading
Render markdown table of contents as React component.
https://github.com/kyoncy/react-markdown-heading
markdown markdown-toc react react-component typescript
Last synced: 2 months ago
JSON representation
Render markdown table of contents as React component.
- Host: GitHub
- URL: https://github.com/kyoncy/react-markdown-heading
- Owner: kyoncy
- Created: 2020-10-12T15:57:57.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2022-02-14T14:34:43.000Z (about 3 years ago)
- Last Synced: 2024-12-07T16:41:41.053Z (3 months ago)
- Topics: markdown, markdown-toc, react, react-component, typescript
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/react-markdown-heading
- Size: 1.96 MB
- Stars: 16
- Watchers: 1
- Forks: 1
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# react-markdown-heading
Render markdown table of contents as React component.
[data:image/s3,"s3://crabby-images/eab84/eab84e455fbf45e578b2f71625994ba1015f2da1" alt="npm version"](https://badge.fury.io/js/react-markdown-heading)
[data:image/s3,"s3://crabby-images/55fb5/55fb5ed91a35997432fe6ec316ac24603acf880b" alt="install size"](https://packagephobia.com/result?p=react-markdown-heading)
[data:image/s3,"s3://crabby-images/aa364/aa364331c46bfb39cd9c213015cc557d5443738d" alt="minified size"](https://bundlephobia.com/result?p=react-markdown-heading)
[data:image/s3,"s3://crabby-images/cd3c4/cd3c46a7de7682661d51af8e538f37d49ced8af4" alt="minzipped size"](https://bundlephobia.com/result?p=react-markdown-heading)
[data:image/s3,"s3://crabby-images/039ba/039ba90b24bf3e76344cfb8becd894e66ea79375" alt="codecov"](https://codecov.io/gh/kyoncy/react-markdown-heading)## Install
```
npm install react-markdown-heading
```## How to Use
```jsx
import React from 'react'
import ReactDOM from 'react-dom'
import ReactMarkdownHeading from 'react-markdown-heading'const markdown = '## h2\n### h3\n#### h4\n### h3\n# h1\n### h3'
render(
{
console.log(headingList)
}}
liClassName="li"
activeAnchorClassName="activeAnchor"
/>,
document.getElementById('root')
)
```
## Option
- **markdown** - `string`, The Markdown source to parse (**required**)
- **ulClassName** - `string`, Class name of the ul tag (optional)
- **liClassName** - `string`, Class name of the li tag (optional)
- **anchorClassName** - `string`, Class name of the anchor tag (optional)
- **hyperlink** - `boolean`, Add hyperlink to text (default `false`)
- **blankSpaceReplaceText** - `string`, Replace blank space in hyperlink to this (default `-`)
- **headingDepth** - `1 | 2 | 3 | 4 | 5 | 6`, Depth of heading to display (default `6`)
- **hyperLinkPrefix** - `string`, Hyperlink prefix (default empty)
- **onChangeHeading** - `(headingList: HeadingType[]) => void`, Change event handler (optional)
- **activeHeading** - `HeadingType[]`, Designate active heading list (optional)
- **activeLiClassName** - `string`, Class name of the active li tag (optional)
- **activeAnchorClassName** - `string`, Class name of the active anchor tag (optional)