目錄
將其與Markdown 結合使用
在應用程序中實現MDX
編輯器支持
MDX 插件和擴展
首頁 web前端 css教學 MDXJS簡介

MDXJS簡介

Apr 08, 2025 am 10:15 AM

An Introduction to MDXJS

Markdown 長期以來一直是程序員編寫文檔的首選格式。它足夠簡單,幾乎每個人都能學習和適應,同時又易於格式化和設置樣式。它非常流行,以至於Markdown 的命令已被用於Slack 和Whatsapp 等聊天應用程序以及Dropbox Paper 和Notion 等文檔應用程序。當GitHub 為README 文檔引入Markdown 支持時,他們也從中渲染了HTML 內容——例如,我們可以插入一些鏈接和圖像元素,它們可以正常渲染。

儘管Markdown 並沒有任何缺陷,但總有改進的空間。這就是Markdown 擴展(MDX) 的用武之地。

在什麼情況下我們會考慮使用MDX 而不是Markdown? MDX 的一個特點是可以在使用普通Markdown 的情況下集成JavaScript。以下是一些說明其便捷性的示例:

  • Frontend Armory 在其教育遊樂場Demoboard 上使用MDX。該遊樂場原生支持MDX,用於創建既可作為演示又可作為文檔的頁面,這對於演示React 概念和組件非常理想。
  • Brent Jackson 提出了一種全新的網站構建方法,將MDX 和Styled System 配對使用。每個頁面都用MDX 編寫,Styled System 為代碼塊設置樣式。它目前正在開發中,您可以在網站上找到更多詳細信息。
  • 使用mdx-deck 或Spectacle 可以使您的下一個演示文稿更有趣。您可以在演示文稿中直接顯示演示,無需切換屏幕!
  • MDX Go、ok-mdx 和Docz 都提供使用MDX 記錄組件庫的工具。您可以直接在Markdown 文檔中放置組件,它就能正常工作™。
  • 一些網站,包括Zeit Now 和Prisma 文檔,都使用MDX 來編寫內容。

如果您想維護一個基於React 的博客,MDX 將大放異彩。使用它意味著當您想要做一些Markdown 中不可能做到的事情(或創建插件)時,您不再需要創建自定義React 組件頁面。我已經在我的博客上使用它一年多了,並且非常喜歡這種體驗。到目前為止,我最喜歡的項目之一是一個我稱之為Playground 的React 組件,它可以用來演示小的HTML/CSS/JavaScript 代碼片段,同時允許用戶編輯代碼。當然,我可以使用一些第三方服務並嵌入演示,但這這樣我就不必加載任何第三方腳本了。

說到嵌入,MDX 使得嵌入由第三方服務(例如YouTube、Vimeo、Giphy 等)創建的iFrame非常容易。

將其與Markdown 結合使用

您可以通過文件名上的.mdx 擴展名來識別用MDX 編寫的文件。但是,讓我們看看實際使用MDX 編寫內容的樣子。

 <code>import InteractiveChart from "../path/interactive-chart"; # Hello - I'm a Markdown heading This is just markdown text<interactivechart></interactivechart></code>
登入後複製

看到了嗎?仍然可以使用Markdown,並且可以在需要交互式可視化或樣式時將其與React 組件一起編寫。這是我作品集中的一個示例:

MDX 的另一個好處是,就像組件一樣,文件是可以組合的。這意味著頁面可以拆分成多個塊並重複使用,一次性渲染所有塊。

 <code>import Header from "./path/Header.mdx" import Footer from "./path/Footer.mdx" # Here goes the actual content. Some random content goes [here](link text)</code>
登入後複製

在應用程序中實現MDX

大多數常見的基於React 的集成平台(如Gatsby 和Next)都有MDX 插件。

要在create-react-app 項目中集成它,MDX 提供了一個可以導入到應用程序中的Babel Macro:

 <code>import { importMDX } from './mdx.macro' const MyDocument = React.lazy(() => importMDX('./my-document.mdx')) ReactDOM.render( <react.suspense fallback="{<div"> Loading...}><mydocument></mydocument></react.suspense> , document.getElementById('root') );</code>
登入後複製

您也可以在他們為此創建的遊樂場上試用MDX。

MDX 貢獻者非常積極地致力於為Vue 提供支持。 GitHub 上已經提供了一個示例。但這還處於Alpha 階段,尚未準備好用於生產環境。

編輯器支持

VS Code、Vim 和Sublime Text 都越來越支持語法高亮和自動完成。但是,在使用過程中,這些確實有一些不足之處,並且難以導航。許多問題都源於無法預測在頁面上下文中我們是使用JavaScript 還是Markdown。這當然是可以改進的。

MDX 插件和擴展

MDX 的一個關鍵優勢是它是內容統一聯盟的一部分,該聯盟組織remark 內容。這意味著MDX 可以直接支持龐大的remark 插件和rehype 插件生態系統——無需重新發明輪子。其中一些插件,包括remark-images 和remark-redact,至少可以說是非凡的。要在MDX 中使用插件,您可以將它們添加到相應的加載器或插件中。您甚至可以通過參考MDX 創建插件指南來編寫自己的MDX 插件。

MDX 只有幾歲,但它在內容領域的影響力一直在增長。從撰寫博客文章和可視化數據到創建交互式演示和演示文稿,MDX 非常適合許多用途——遠遠超出了我們在本文介紹中介紹的內容。

以上是MDXJS簡介的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1656
14
CakePHP 教程
1415
52
Laravel 教程
1309
25
PHP教程
1257
29
C# 教程
1229
24
Google字體可變字體 Google字體可變字體 Apr 09, 2025 am 10:42 AM

我看到Google字體推出了新設計(Tweet)。與上一次大型重新設計相比,這感覺更加迭代。我幾乎無法分辨出區別

如何使用HTML,CSS和JavaScript創建動畫倒計時計時器 如何使用HTML,CSS和JavaScript創建動畫倒計時計時器 Apr 11, 2025 am 11:29 AM

您是否曾經在項目上需要一個倒計時計時器?對於這樣的東西,可以自然訪問插件,但實際上更多

HTML數據屬性指南 HTML數據屬性指南 Apr 11, 2025 am 11:50 AM

您想了解的有關HTML,CSS和JavaScript中數據屬性的所有信息。

如何通過CSS選擇第一個類名為item的子元素? 如何通過CSS選擇第一個類名為item的子元素? Apr 05, 2025 pm 11:24 PM

在元素個數不固定的情況下如何通過CSS選擇第一個指定類名的子元素在處理HTML結構時,常常會遇到元素個數不�...

為什麼Flex佈局中的紫色斜線區域會被誤認為是'溢出空間”? 為什麼Flex佈局中的紫色斜線區域會被誤認為是'溢出空間”? Apr 05, 2025 pm 05:51 PM

關於Flex佈局中紫色斜線區域的疑問在使用Flex佈局時,你可能會遇到一些令人困惑的現象,比如在開發者工具(d...

使Sass更快的概念證明 使Sass更快的概念證明 Apr 16, 2025 am 10:38 AM

在一個新項目開始時,Sass彙編發生在眼睛的眨眼中。感覺很棒,尤其是當它與browsersync配對時,它重新加載

我們如何創建一個在SVG中生成格子呢模式的靜態站點 我們如何創建一個在SVG中生成格子呢模式的靜態站點 Apr 09, 2025 am 11:29 AM

格子呢是一塊圖案布,通常與蘇格蘭有關,尤其是他們時尚的蘇格蘭語。在Tar​​tanify.com上,我們收集了5,000多個格子呢

在前端開發中,如何使用CSS和JavaScript實現類似Windows 10設置界面的探照燈效果? 在前端開發中,如何使用CSS和JavaScript實現類似Windows 10設置界面的探照燈效果? Apr 05, 2025 pm 10:21 PM

在前端開發中如何實現類似Windows...

See all articles