Note
This project is part of the ZikoJS ecosystem.
A Markdown preprocessor for Zikojs. Markdown in Zikojs. It combines the simplicity of Markdown syntax with the power and flexibility of Javascript
npm i mdzjs
import {defineConfig} from "vite"
import MDZ from "mdzjs/vite"
export default defineConfig({
plugins : [
MDZ()
]
})
Article.mdz :
---
title : MDZ
name : world
__props__ :
background : tomato
data : []
---
import data from "./data.js";
import InteractiveComponent from "./InteractiveComponent.js";
# Hello {name}
<InteractiveComponent data={data} background={tomato}/>
// main.js
import Article,{title} from "./Article.mdz"
-
Simple Integration : Write Markdown as usual, and inject Zikojs elements wherever needed.
-
Extensible : Create custom interactive components using Zikojs and use them in any Markdown file.
-
Reusable : MDZ exports a default functional component, allowing you to call it multiple times with different data, enabling dynamic and versatile use.
-
Frontmatter Support : Use
YAML
syntax in to include metadata like titles, descriptions, or configurations in your Markdown files, and define props to pass data dynamically to Zikojs components. -
Markdown : Use standard Markdown syntax for writing content.
-
JSX Syntax : Write components in JSX within Markdown, enabling easy integration of Zikojs elements with JavaScript and HTML..
-
Props : Pass data to components through props, enabling dynamic rendering and customization of content within your Markdown files.
-
ESM : Supports ECMAScript Modules (ESM), allowing you to import and export modules
-
Expressions : MDZjs lets you use JS expressions inside curly braces, like Hello {name}. These expressions can be full JS programs, as long as they evaluate to something renderable. For example, you can use an IIFE like this:
Hello {(()=>{
const names = ["world", "everyone"];
const {length} = names
return names[Math.floor(Math.random()*length)]
})()}
- Internal scripts : Include JS logic that runs alongside MDZjs components but isn't rendered in the output. They can initialize variables or perform side effects...
<script>
console.log("Hello from MDZjs")
let addons = [
"ziko-gl",
"ziko-lottie",
"ziko-chart"
]
// The addons variable can be accessed and used in MDZjs expressions
</script>
- Interleaving : You can use inline markdown elements inside HTML or Zikojs Components
<Header background={background}>
***Hello {name}***
</Header>
If you appreciate the project, kindly demonstrate your support by giving it a star!