1

我用Parsedown将我的 Markdown 转换为 HTML,例如:

$pd->text('# My First heading');

想要自动使用第一个站点标题 (h1) 作为自定义菜单的条目。我已经查看了源代码,但无法找到获取所有标题的好方法。

也许有一些elements功能。有没有人有想法获得全部或至少第一个标题。

4

2 回答 2

5

@tobias-redmann

想不出一个获取所有标题的好方法

我假设你已经解决了这个问题。但是由于我遇到了同样的问题并想出了答案,我想为那些将面临同样问题的人分享一些信息。

TL;博士

使用 Parsedown 获取 ToC(目录)。

<?php

include('Parsedown.php');

class Extension extends Parsedown
{
    public $array_line = array();

    // Override
    protected function blockHeader($Line)
    {
        // Parse $Line to parent class
        $Block = Parsedown::blockHeader($Line);

        // Set headings
        if(isset($Block['element']['name'])){
            $Level = (integer) trim($Block['element']['name'],'h');
            $this->array_line[] = [
                'text'  => $Block['element']['name'],
                'level' => $Level,
            ];
        }

        return $Block;
    }
}

$text = file_get_contents('YourMarkdownFile.md');

$Parsedown   = new Extension();
$string_body = $Parsedown->text($text);
$array_ToC   = $Parsedown->array_line;

print_r($array_ToC);
//echo $string_body;

TS;DR(详细信息)

首先,正如@emanuil-rusev 所说,覆盖该blockHeader方法,您可以从markdown 文本中获取所有标题。

更具体地说,当您调用text($text)方法时,它会解析给定的降价字符串。

在解析时,该blockHeader($Line)方法将在每一行调用一个数组参数,如下所示。

$Line => [
    "body"   => "# SampleHead",
    "indent" => 0,
    "text"   => "# SampleHead",
]

原始(父)类的blockHeader($Line)方法转换$Line为以下数组($Block)。

$Block => [
    "element" => [
        "name"    => "h1",
        "text"    => "# SampleHead",
        "handler" => "line",
    ],
]

因此,获取所有标题的最简单方法是每次将它们存储到一个数组中。

获取目录的完整脚本(扩展名)

查看我的仓库: https ://github.com/KEINOS/parsedown-extension_table-of-contents

于 2018-01-22T12:05:27.833 回答
4

Parsedown的作者在这里。

您应该能够通过创建一个覆盖该blockHeader方法的扩展来实现这一点。基本上,覆盖方法应该修改父方法的结果。

查看Parsedown wiki了解更多信息。

于 2015-01-27T18:29:20.557 回答