首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何防止Markdown将生成的超文本标记语言包装在<p>元素中?

如何防止Markdown将生成的超文本标记语言包装在<p>元素中?
EN

Stack Overflow用户
提问于 2012-12-09 06:32:15
回答 4查看 3.1K关注 0票数 18

更新:奖金是针对使用“标记”库的解决方案的。

此Markdown代码:

代码语言:javascript
复制
*foo*

将生成以下HTML代码:

代码语言:javascript
复制
<p><em>foo</em></p>

现场演示: https://jsbin.com/luganot/edit?js,console

但是,我已经将生成的HTML代码注入到内联上下文中,如下所示:

代码语言:javascript
复制
<p> text [inject generated HTML here] text </p>

所以我不希望<p>元素包装生成的HTML代码。我只希望将*分隔符转换为<em>、元素等。

有没有办法告诉Markdown转换器不要生成<p>包装器?目前,我正在对生成的HTML字符串执行.slice(3,-4),它确实删除了<p></p>标记,但这显然不是我想长期使用的解决方案。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2017-08-20 12:35:10

您可以跳过块词法分析部分,改为使用inlineLexer。

代码语言:javascript
复制
html = marked.inlineLexer(markdown, [], options);

//example
marked.inlineLexer('*foo*', []) // will output '<em>foo</em>'
票数 7
EN

Stack Overflow用户

发布于 2012-12-10 23:30:33

使用jQuery是一种选择吗?这将在以下情况下工作:

代码语言:javascript
复制
var $text = $(new Showdown.converter().makeHtml( '*foo*' ) );
console.log( $text.html() );
票数 3
EN

Stack Overflow用户

发布于 2015-02-18 20:34:34

我也在寻找解决这个问题的方法,这时我发现了这个SO线程。我在这里还没有找到好的解决方案,所以我写了我自己的。

代码语言:javascript
复制
var markdown = new Showdown.converter().makeHtml( '*foo*' );
console.log(markdown.replace(/^<p>|<\/p>$/g, ''));
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13782605

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档