有个问题哈,
getHTML 的结果被 html2md 转换的结果不正确,比如:
- 部分代码块的的标识转换没了
这应该是 lute 通用的转换函数所至,
时间有限, 还未阅读全部文档,
有哪位大佬有这两个 api 无损转换的例子吗
有个问题哈,
getHTML 的结果被 html2md 转换的结果不正确,比如:
这应该是 lute 通用的转换函数所至,
时间有限, 还未阅读全部文档,
有哪位大佬有这两个 api 无损转换的例子吗
我目前有三个方案,
html2md
前处理 html 字符串,<div class="language-mindmap">- 教程</div>
转换成 <pre><code class="language-mindmap">- 教程</code></pre>
export const getHTML = (vditor: IVditor) => {
if (vditor.currentMode === "sv") {
return vditor.lute.Md2HTML(getMarkdown(vditor));
} else if (vditor.currentMode === "wysiwyg") {
return vditor.lute.VditorDOM2HTML(vditor.wysiwyg.element.innerHTML);
} else if (vditor.currentMode === "ir") {
return vditor.lute.VditorIRDOM2HTML(vditor.ir.element.innerHTML);
}
};
HTML2Md
方法,对 md 的转换规则做特殊支持我用的是 第一个方案
function transformHtml(html) {
const box = document.createElement('div');
box.innerHTML = html;
const supMap = {};
// 注意: 有先后顺序,脚注也可以包含自定义区块
const selector = [
// sup: class="footnotes-ref"
{
css: 'sup.footnotes-ref',
convert: (node) => {
const a = node.querySelector('a');
const href = a && a.getAttribute('href');
const [_, id] = /#(.+)/g.exec(href) || [];
const mark = a.innerText;
supMap[id] = mark;
node.outerHTML = `[^${mark}]`;
}
},
// supDefs:,
{
css: 'div.footnotes-defs-div',
convert: (node) => {
let defIndex = 1;
const defs = node.querySelectorAll('.footnotes-defs-ol>li');
const refs = node.querySelectorAll('.footnotes-defs-ol .vditor-footnotes__goto-ref');
// 去掉内容的跳转
refs.forEach(node => node.outerHTML = '');
const result = Array.from(defs).map(li => {
const id = node.getAttribute('id');
// 注意这里的div,不加这层容器解释的内容不正确
return `<div>[^${supMap[id] || defIndex++}]: ${li.innerHTML}</div>`;
}).join('');
node.outerHTML = result;
}
},
// customCode
{
// language-math
css: 'div[class^="language-"]',
convert: (node) => {
const clsName = node.getAttribute('class');
const [_, language] = /\blanguage-([^\s]+)/g.exec(clsName);
let str = '';
switch (language) {
case 'math':
str = `$$
${node.innerText}
$$`
break;
default:
str = `<pre><code class="${clsName}" >${node.innerHTML}</code></pre>`
}
node.outerHTML = str;
}
}
]
selector.forEach(({ css, convert }) => {
box.querySelectorAll(css).forEach(convert)
});
return box.innerHTML;
}
机器学习(Machine Learning)是一门多领域交叉学科,涉及概率论、统计学、逼近论、凸分析、算法复杂度理论等多门学科。专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能。
互联网运维工作,以服务为中心,以稳定、安全、高效为三个基本点,确保公司的互联网业务能够 7×24 小时为用户提供高质量的服务。
持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。
开源中国是目前中国最大的开源技术社区。传播开源的理念,推广开源项目,为 IT 开发者提供了一个发现、使用、并交流开源技术的平台。目前开源中国社区已收录超过两万款开源软件。
子曰:“工欲善其事,必先利其器。”
Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。
ActiveMQ 是 Apache 旗下的一款开源消息总线系统,它完整实现了 JMS 规范,是一个企业级的消息中间件。
记录并分享人生的经历。
Logseq 是一个隐私优先、开源的知识库工具。
Logseq is a joyful, open-source outliner that works on top of local plain-text Markdown and Org-mode files. Use it to write, organize and share your thoughts, keep your to-do list, and build your own digital garden.
微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。
MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是一个基于分布式文件存储的数据库,由 C++ 语言编写。旨在为应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似 JSON 的 BSON 格式,因此可以存储比较复杂的数据类型。
星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。
Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 Velocity、 FreeMarker 等,它也可以轻易的与 Spring 等 Web 框架进行集成作为 Web 应用的模板引擎。与其它模板引擎相比,Thymeleaf 最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个 Web 应用。
Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。
SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。
一些有用的避坑指南。
心是产生任何想法的源泉,心本体会陷入到对自己本体不能理解的状态中,因为心能产生任何想法,不能分出对错,不能分出自己。
Python 是一种面向对象、直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定。它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务。它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用缩进来定义语句块。
InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。
以太坊(Ethereum)并不是一个机构,而是一款能够在区块链上实现智能合约、开源的底层系统。以太坊是一个平台和一种编程语言 Solidity,使开发人员能够建立和发布下一代去中心化应用。 以太坊可以用来编程、分散、担保和交易任何事物:投票、域名、金融交易所、众筹、公司管理、合同和知识产权等等。
PostgreSQL 是一款功能强大的企业级数据库系统,在 BSD 开源许可证下发布。
Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。
知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。
SQL Server 是由 [微软] 开发和推广的关系数据库管理系统(DBMS),它最初是由 微软、Sybase 和 Ashton-Tate 三家公司共同开发的,并于 1988 年推出了第一个 OS/2 版本。
如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。
域名(Domain Name),简称域名、网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于