unified

Content as structured data

We compile content to syntax trees and syntax trees to content.
We also provide hundreds of packages to work on the trees in between.
You can build on the unified collective to make all kinds of interesting things.

Learn

We provide the interface: for parsing, inspecting, transforming, and serializing content. You work on structured data. Learn how to plug building blocks together, write your own, and make things with unified.

  1. Intro to unified

    Guide that summarizes the what and why of unified

    1. guide
    2. introduction
    3. welcome
  2. Use unified

    Guide that delves into transforming markdown to HTML

    1. guide
    2. rehype
    3. remark
    4. transform
    5. use
  3. Tree traversal

    How to do tree traversal (also known as walking or visiting a tree)

    1. recipe
    2. traverse
    3. tree
    4. unist
    5. visit
    6. walk
  4. Find a node

    How to find a node in any unist syntax tree

    1. recipe
    2. find
    3. node
    4. traverse
    5. tree
    6. walk
  5. Support tables in remark

    How to support GitHub-style tables in remark (or react-markdown)

    1. recipe
    2. gfm
    3. github
    4. plugin
    5. remark
    6. table
  6. See 15 other articles

Sponsor

To support our efforts financially, sponsor us on GitHub, thanks.dev, or OpenCollective. This lets us spend more time maintaining our projects and developing new ones.

  1. Vercel

    Develop. Preview. Ship. – Creators of nextjs.org

  2. GatsbyJS

  3. Motif

    When content meets code, magic happens ✨

  4. HashiCorp

  5. GitBook

  6. See 81 other sponsors

Explore

The ever growing ecosystem that the unified collective provides today consists of 365 open source projects, with a combined 63k stars on GitHub. In comparison, the code that the collective maintains is about 102 Moby Dicks or 40 Linuxes. In the last 30 days, the 542 packages maintained in those projects were downloaded 1.9b times from npm. Much of this is maintained by our teams, yet others are provided by the community.

  1. mdast-util-find-and-replace

    mdast utility to find and replace text in a tree
    1. 76%
    2. 15m
    3. 1.03 kB
  2. micromark-util-classify-character

    micromark utility to classify whether a character is whitespace or punctuation
    1. 79%
    2. 24m
  3. unist-util-visit-parents

    unist utility to recursively walk over nodes, with ancestral information
    1. 83%
    2. 63m
  4. mdast-util-gfm-autolink-literal

    mdast extension to parse and serialize GFM autolink literals
    1. 75%
    2. 15m
    3. 2 kB
  5. hast-util-parse-selector

    hast utility to create an element from a simple CSS selector
    1. 81%
    2. 22m
    3. 345 B
  6. See 542 packages and 365 projects

Build

We provide the building blocks: from tiny, focussed, modular utilities to plugins that combine them to perform bigger tasks. And much, much more. You can build on unified, mixing and matching building blocks together, to make all kinds of interesting new things.

  1. Prettier

    Uses unified to format markdown

  2. Gatsby

    Uses unified to pull content into GraphQL

  3. Write Music

    Uses unified to visualize sentence length

  4. Node.js

    Uses unified to check and build their docs

  5. alex

    Uses unified to catch insensitive, inconsiderate writing

  6. See 21 other cases

Work

Maintaining the collective, developing new projects, keeping everything fast and secure, and helping users, is a lot of work. In total, we’ve closed 5.1k issues/PRs while 162 are currently open (3%). In the last 30 days, we’ve cut 7 new releases.

  1. jaywcjlove/rehype-video@2.3.0·

  2. ybiquitous/remark-lint-code-block-syntax@0.11.0·

  3. ybiquitous/remark-lint-code-block-syntax@0.10.0·

    What's Changed

    Full Changelog: https://github.com/ybiquitous/remark-lint-code-block-syntax/compare/v0.9.0...v0.10.0

  4. Explore recent releases