showdown实现markdown预览功能

Showdown.js 简介

Showdown.js 是一个JavaScript库,用于将Markdown文本转换为HTML。由于其轻量级和易于使用的特性,它广泛应用于需要Markdown渲染的前端项目中。

安装 Showdown.js

Showdown.js 可以通过npm或直接通过脚本标签引入到项目中。

通过 NPM 安装

bash 复制代码
npm install showdown

通过脚本标签引入

html 复制代码
<script src="https://cdn.jsdelivr.net/npm/showdown@1.9.1/dist/showdown.min.js"></script>

基本使用

一旦安装了Showdown.js,就可以创建一个转换器实例,并用它来将Markdown转换为HTML。

示例代码

javascript 复制代码
// 引入 Showdown
const showdown = require('showdown');

// 创建转换器实例
const converter = new showdown.Converter();

// Markdown 文本
const markdown = '# 标题\n\n这是一段**粗体**文本。';

// 转换为 HTML
const html = converter.makeHtml(markdown);

console.log(html);

高级配置

Showdown.js 支持多种配置选项,可以用来调整Markdown到HTML的转换过程。

示例:启用表格

javascript 复制代码
// 配置转换器以支持Markdown表格
converter.setOption('tables', true);

// 包含表格的Markdown文本
const markdownWithTable = '| 标题1 | 标题2 |\n|-------|-------|\n| 单元格1 | 单元格2 |';

// 转换为 HTML
const htmlWithTable = converter.makeHtml(markdownWithTable);

console.log(htmlWithTable);

Markdown 扩展

Showdown.js 允许开发者通过扩展来增加新的Markdown语法或修改现有的渲染规则。

示例:创建自定义扩展

javascript 复制代码
// 自定义扩展,用于将 @@ 包围的文本转换为红色
const myExtension = () => {
  return [{
    type: 'lang',
    filter: function (text) {
      return text.replace(/@@(.+?)@@/g, '<span style="color: red;">$1</span>');
    }
  }];
};

// 向转换器添加扩展
converter.addExtension(myExtension, 'myExtension');

// 包含自定义语法的Markdown文本
const customMarkdown = '这是一段@@红色@@文本。';

// 转换为 HTML
const customHtml = converter.makeHtml(customMarkdown);

console.log(customHtml);

Showdown.js 与前端框架集成

Showdown.js 可以轻松集成到流行的前端框架,如React或Vue中,用于动态渲染Markdown内容。

React 示例

jsx 复制代码
import React, { useState } from 'react';
import showdown from 'showdown';

const MarkdownEditor = () => {
  const [markdown, setMarkdown] = useState('');
  const converter = new showdown.Converter();

  return (
    <div>
      <textarea
        onChange={(e) => setMarkdown(e.target.value)}
        placeholder="输入Markdown文本"
      />
      <div
        dangerouslySetInnerHTML={{ __html: converter.makeHtml(markdown) }}
      />
    </div>
  );
};

export default MarkdownEditor;

结论

Showdown.js 是一个功能强大且灵活的库,适用于将Markdown转换为HTML的任何场景。通过其简单的API和丰富的配置选项,Showdown.js 成为前端开发者处理Markdown的首选工具。

相关推荐
木斯佳3 分钟前
前端八股文面经大全:阿里云AI应用开发一面(2026-03-20)·面经深度解析
前端·人工智能·阿里云·ai·智能体·流式打印
我叫黑大帅10 分钟前
JS中的两大定时器
前端·javascript·面试
掘金安东尼18 分钟前
⏰前端周刊第 458 期v2026.3.24
前端·javascript·面试
前端付豪31 分钟前
实现必要的流式输出(Streaming)
前端·后端·agent
张元清33 分钟前
useMediaQuery:React 响应式设计完全指南
前端·javascript·面试
小金鱼Y34 分钟前
一文吃透 JavaScript 防抖:从原理到实战,让你的页面不再 “手抖”
前端·javascript·面试
Z兽兽37 分钟前
React 18 开发环境下useEffect 会执行两次,原因分析及解决方案
前端·react.js·前端框架
紫_龙39 分钟前
最新版vue3+TypeScript开发入门到实战教程之Vue3详解props
前端·vue.js·typescript
树上有只程序猿1 小时前
这波低代码热,能维持多久
前端
姓王名礼1 小时前
这是一个完整的全栈交付包,包含Vue3 前端交互界面(集成数字人视频流、ECharts 图表、语音对话)和Docker Compose 一键部署脚本。
前端·docker·echarts