JS加载解析Markdown文档过程详解

这篇文章主要介绍了JS加载解析Markdown文档过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

网上有很多网站会通过.md文档来做页面内容,很好奇,这是怎么做的?

出于好奇,建了一个test.md文件:

# Hello World!

asdfa

asd

*斜体文本*

**粗体文本**

***斜粗体文本***

分隔线(如下)

***

* * *

****

– – –

———–

GOOGLE.COM

~~删除线~~

<u>下划线</u>

JS加载解析Markdown文档过程详解 (https://www.wp-admin.cn/) javascript教程 第1张

用浏览器打开之后,结果就被原封不动的输出来了,浏览器根本不会解析这玩意… 跟阮老师的blog相差好大啊~呵呵~还是太天真了!

然后,发现:

JS加载解析Markdown文档过程详解 (https://www.wp-admin.cn/) javascript教程 第2张

原来markdown文本还是需要用marked.js这么一个库来解析的!于是乎,依葫芦画个瓢

<!doctype html>

<html>

<head>

<meta charset=”utf-8″/>

<title>md文档内容转成html显示</title>

</head>

<body>

<div id=”content” style=”width: 500px;height: 500px;overflow: auto”></div>

<div style=”margin-top: 30px”>

<form name=”form” action=”” method=”post”>

<select name=”q”>

<option value=”md/gs.md”>公式</option>

<option value=”md/test.md”>第一个Markdown文档</option>

</select>

<input type=”button” value=”显示” onclick=”showMarkdown()”>

</form>

</div>

<script type=”text/javascript” src=’https://cdn.jsdelivr.net/npm/marked/marked.min.js’></script>

<script type=”text/javascript”>

function showMarkdown() {

var f = form;

var xmlhttp;

if (window.XMLHttpRequest) {

xmlhttp = new XMLHttpRequest();

} else {

xmlhttp = new ActiveXObject(‘Microsoft.XMLHttp’);

}

xmlhttp.onreadystatechange = function() {

if(xmlhttp.readyState == 4 && xmlhttp.status == 200) {

document.getElementById(‘content’).innerHTML = marked(xmlhttp.responseText);

}

}

// 向服务器发送请求

xmlhttp.open(‘GET’, f.q.value, true);

xmlhttp.send();

}

</script>

</body>

</html>

于是就有了下面的样子:

JS加载解析Markdown文档过程详解 (https://www.wp-admin.cn/) javascript教程 第3张

原理就是用ajax请求,取到 .md文件里的内容,再通过marked.js提供的marked()方法将markdown语法的文本转成html文档。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

JS加载解析Markdown文档过程详解 (https://www.wp-admin.cn/) javascript教程 第4张

相关推荐

发表评论

房先生
我们将24小时内回复。
2023-12-16 03:05:06
您好,有任何疑问请与我们联系!
您的工单我们已经收到,我们将会尽快跟您联系!
[加我微信]
chaoneo
注:点击复制微信号并打开微信APP,添加好友后进行聊天。
[电话联系]
13585372227
[电子邮件]
[email protected]
取消

选择聊天工具: