javascript - 如何使用 showdown.js 将表格文本打印到 md 表格?

标签 javascript jquery html css showdown

我想使用 showdown.js 打印 md 表。但是,它似乎并没有像我预期的那样正确地转换为 Markdown 表。

我尝试将选项('table option')设置为“true”并将文本转换为 md。但是,不起作用。

下面是我实现的功能,供大家引用。

setMdConvert() <= 正如我所说,我只是尝试了所有选项为 true。

getTechDescriptionMd() <= 将任意 markdown 文本转换为 markdown 表格的测试函数

function setMdConvert() {
    var mdConverter = new showdown.Converter();
    var options = showdown.getOptions();
    var keys = Object.keys(options);

    keys.forEach((key) => {
        if(options[key].constructor === boolConstructor)
            mdConverter.setOption(key, true);
    });

    console.log(mdConverter.getOptions());

    return mdConverter;
}

function getTechDescriptionMd() {
    var text = '| h1    |    h2   |      h3 |' +
               '|:------|:-------:|--------:|' +
               '| 100   | [a][1]  | ![b][2] |' +
               '| *foo* | **bar** | ~~baz~~ |';
    var html = mdConverter.makeHtml(text);

    $('.desc-viewer').html(html);
}

结果:

| h1 | h2 | h3 ||:------|:-------:|--------:|| 100 | [a][1] | ![b][2] || foo | bar | baz |

还有其他我想念的选择吗?

最佳答案

这是对我有用的 .getTechDescriptionMd() 的修改版本。我添加了我在昨天的评论中已经提到的换行符,另外我初始化了 mdConverter 并将其选项“tables”设置为 true(受 documentation 启发)。

现在看起来像这样:

function getTechDescriptionMd() {
    var text = '| h1    |    h2   |      h3 |\n' +
               '|:------|:-------:|--------:|\n' +
               '| 100   | [a][1]  | ![b][2] |\n' +
               '| *foo* | **bar** | ~~baz~~ |';

    var mdConverter = new showdown.Converter();
    mdConverter.setOption('tables', true);
    var html = mdConverter.makeHtml(text);
    $('.desc-viewer').html(html);
}

我得到的结果是:

<table>
<thead>
<tr>
<th style="text-align:left;">h1</th>
<th style="text-align:center;">h2</th>
<th style="text-align:right;">h3</th>
</tr>
</thead>
<tbody>
<tr>
<td style="text-align:left;">100</td>
<td style="text-align:center;">[a][1]</td>
<td style="text-align:right;">![b][2]</td>
</tr>
<tr>
<td style="text-align:left;"><em>foo</em></td>
<td style="text-align:center;"><strong>bar</strong></td>
<td style="text-align:right;">~~baz~~</td>
</tr>
</tbody>
</table>

关于javascript - 如何使用 showdown.js 将表格文本打印到 md 表格?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56356702/

相关文章:

javascript - md-contact-chips 返回搜索过滤器不起作用

Javascript - 删除 split 方法

javascript - 鼠标悬停和鼠标高度上的图像叠加?

javascript - 嵌套点击处理程序不好吗?

jquery - 对象没有方法 'flexslider'

html - Gmail 应用程序 - 响应式签名(媒体查询)

JavaScript OOP 类和声明

javascript - 使用 r.js 来优化 require.js 文件

php - 增加值(value)按钮

html - 图像出现然后消失