使用PHP正则可实现Markdown到HTML的基础转换,适用于简单场景。1. 通过正则匹配标题、粗体、斜体、链接等语法,依次替换为对应HTML标签。2. 核心函数按顺序处理:先转换标题(#至h1-h6),再处理粗体(*或__替换为strong)、斜体(或_替换为em),随后解析链接(text转为a标签),最后将非空行包裹p标签。3. 示例输入“# Hello\nThis is bold and italic.\nLink”输出对应HTML结构。注意:正则方案对复杂语法支持有限,易出现误匹配,生产环境推荐使用Parsedown等专用库。

使用PHP正则解析和转换Markdown格式是一种轻量级的实现方式,适合简单场景。虽然完整的Markdown解析推荐使用像erusev/parsedown这样的库,但通过正则表达式可以快速实现基础功能,如标题、粗体、斜体、链接等常见语法的转换。
1. 基础语法映射与正则设计
将Markdown语法一对一转换为HTML标签,关键在于编写准确的正则表达式。以下是一些常用规则:
- 标题(#):/^#{1,6}\s+(.*?)/m 匹配以1-6个#开头的行,替换为对应层级的h1-h6标签。
- 粗体(**或__):/\*\*(.*?)\*\*/ 或 /__([^_]+?)__/ 替换为 标签。
- 斜体(*或_):/\*(.*?)\*/ 或 /_([^_]+?)_/ 转为 标签。
- 链接([text](url)):/\[([^]]+)]$$([^)]+)$$/ 提取文本和URL,生成a标签。
-
段落:用换行符分隔的非空行包裹在
标签中。
2. 实现核心转换函数
定义一个函数接收Markdown字符串,逐条应用正则替换:
function markdownToHtml($markdown) {$html = $markdown;
// 标题
$html = preg_replace('/^#{6}\s+(.*?)/m', '
$1
', $html);$html = preg_replace('/^#{5}\s+(.*?)/m', '
$1
', $html);$html = preg_replace('/^#{4}\s+(.*?)/m', '
$1
', $html);$html = preg_replace('/^#{3}\s+(.*?)/m', '
$1
', $html);$html = preg_replace('/^#{2}\s+(.*?)/m', '
$1
', $html);$html = preg_replace('/^#\s+(.*?)/m', '
$1
', $html);// 粗体和斜体(注意顺序,避免嵌套冲突)
$html = preg_replace('/\*\*(.*?)\*\*/', '$1', $html);
$html = preg_replace('/\*(.*?)\*/', '$1', $html);
// 链接
$html = preg_replace('/$([^$$]+)$$$([^$$]+)$$/', '$1', $html);
// 段落:将非空行包裹在p标签中
$lines = explode("\n", $html);
$parsed = [];
foreach ($lines as $line) {
if (trim($line) !== '') {
// 跳过已处理的块级标签
if (!preg_match('/^
$line = '
' . $line . '
立即学习“PHP免费学习笔记(深入)”;
';}
}
$parsed[] = $line;
}
$html = implode("\n", $parsed);
return $html;
}
3. 使用示例与注意事项
调用函数即可完成转换:
$md = "# Hello\nThis is **bold** and *italic*.\n[Link to Google]$$https://google.com$$";echo markdownToHtml($md);
输出结果为:
Hello
This is bold and italic.
注意:正则方法对复杂嵌套(如代码块、列表、引用)支持有限,且可能误匹配。生产环境建议使用成熟解析器。若只需支持简单内容,此方法足够高效。
基本上就这些,不复杂但容易忽略细节。











