Socket
Socket
Sign inDemoInstall

markdown-navbar

Package Overview
Dependencies
7
Maintainers
1
Versions
29
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    markdown-navbar

Best markdown navigation bar for React.


Version published
Maintainers
1
Install size
1.34 MB
Created

Changelog

Source

1.4.3 (2020-08-12)

Bug Fixes

  • the exception in Safari due to too many calls to the history.replacestate method (2834372)
  • 文档内容无标题时的页面滚动报错 (a3353a6)
  • 非标题行内出现#号导致的导航解析不正确 (074cb10)

<a name="1.4.0"></a>

Features

  • scroll page to target heading when event hashchange has been triggered (e76941d)

<a name="1.3.7"></a>

Readme

Source

Markdown-Navbar

npm npm npm GitHub file size in bytes

A React component renders an interactive navbar panel of Markdown docs for your blog or website.

Demo on Netlify

Features

Implement some regular functions easily by using this component, such as:

  • Display the structure tree of your article defined by the headings.
  • Render anchors that navigate to specific headings in the article.
  • Share one URL to readers to navigate to a specific area of the article.

Install

yarn add markdown-navbar # or `npm i markdown-navbar --save`

Quickstart

Edit markdown-navbar-demo-online

import React from 'react';
import ReactDOM from 'react-dom';
// One third-part component for render markdown documentation
import ReactMarkdown from 'react-markdown';
import MarkdownNavbar from 'markdown-navbar';
// The default style of markdown-navbar should be imported additionally
import 'markdown-navbar/dist/navbar.css';

const article = `# Markdown-Navbar Demo

## Chicken Chicken

Chicken Chicken Chicken Chicken Chicken.

* Chicken Chicken Chicken Chicken Chicken.
* Chicken Chicken Chicken Chicken Chicken.
* Chicken Chicken Chicken Chicken Chicken.

### Chicken Chicken Chicken

Chicken Chicken Chicken Chicken Chicken.

#### Chicken Chicken Chicken Chicken

Chicken Chicken Chicken Chicken Chicken Chicken.`;

function App() {
  return (
    <div className="App">
      <div className="article">
        <ReactMarkdown source={article} />
      </div>
      <div className="navigation">
        <MarkdownNavbar source={article} />
      </div>
    </div>
  );
}

ReactDOM.render(<App />, document.getElementById('root'));

Tips

  • The component only parses article headings at level 2 and below. The article title, which is usually used once in an article, will not appear in the navigation bar.
  • The component needs to be used in conjunction with your article content. When using this component, you must ensure that your article under the same page content.
  • Please confirm that every heading of your markdown document is different by each other when the value of property declarative is setted as true.

Props

PropertyData TypeDefault ValueDescription
classNamestring""The className that defines the outermost container of navbar
sourcestring""Markdown text content
headingTopOffsetnumber0Anchor displacement relative to the top of the window (for the anchor jump)
updateHashAutobooleantrueAutomatically update the hash value of browser address when page scrolling if true
declarativebooleanfalseUse the text of the title from Markdown content as the hash value for the anchor if true
orderedbooleantrueWhether the title contains a numerical prefix, such as: 1. 2. 2.2
onNavItemClickfunction(event, element, hashValue) => {}The event callback function after clicking navbar item
onHashChangefunction(newHash, oldHash) => {}The event callback function before the hash value of browser address changing

License

MIT license

Keywords

FAQs

Last updated on 12 Aug 2020

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc