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 85 other sponsors

Explore

The ever growing ecosystem that the unified collective provides today consists of 356 open source projects, with a combined 65k 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 533 packages maintained in those projects were downloaded 2.1b times from npm. Much of this is maintained by our teams, yet others are provided by the community.

  1. unist-util-stringify-position

    unist utility to serialize a node, position, or point as a human readable location
    1. 82%
    2. 56m
    3. 278 B
  2. vfile

    Virtual file format for text processing
    1. 85%
    2. 48m
    3. 0.954 B
  3. micromark-factory-label

    micromark factory to parse labels (found in media, definitions)
    1. 79%
    2. 28m
    3. 554 B
  4. mdast-util-gfm-table

    mdast extension to parse and serialize GFM tables
    1. 76%
    2. 17m
    3. 4.77 B
  5. micromark-util-sanitize-uri

    micromark utility to sanitize urls
    1. 79%
    2. 30m
    3. 662 B
  6. See 533 packages and 356 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 134 are currently open (3%). In the last 30 days, we’ve cut 2 new releases.

  1. syntax-tree/hast-util-to-html@9.0.4·

    Fix

    Miscellaneous

    Full Changelog: https://github.com/syntax-tree/hast-util-to-html/compare/9.0.3...9.0.4

  2. rehypejs/rehype-dom@rehype-dom-stringify@4.0.2·

  3. micromark/micromark@micromark-util-subtokenize@2.0.3·

  4. Explore recent releases