关于如何转换MarkDown文本并在Html内进行显示

今天遇到一个问题,从ChatGpt的API获取的文本格式为MarkDown,在HTML上使用textarea控件显示的时候就只是文字格式,并没有对MarkDown格式进行处理,今天就分享一下如何在Html上进行MarkDown格式文本的显示

1.创建一个HTML页面,包括textarea和一个用于显示Markdown内容的div:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Textarea to Markdown</title>
    <script src="https://cdn.jsdelivr.net/npm/marked/marked.min.js"></script>
</head>
<body>
    <textarea style="font-size: 20px; width: 300px; height: 800px;" id="responseBox" name="responseBox" rows="4" cols="150" readonly>

2.将文本输入到div控件的.innerHTML属性上

html 复制代码
Example Markdown
This is an example of Markdown text.

Item 1

Item 2
</textarea>
<button onclick="convertToMarkdown()">Convert to Markdown</button>
<div id="markdownDisplay"></div>

php
Copy code
  <script>
      function convertToMarkdown() {
          var text = document.getElementById('responseBox').value;
          var markdownContent = marked(text);
          document.getElementById('markdownDisplay').innerHTML = markdownContent;
      }
  </script>
  </body>
  </html>

3.代码解释

  • textarea 元素用于输入或显示文本内容。
  • button 元素用于触发转换操作。
  • div 元素用于显示转换后的Markdown内容。
  • 使用JavaScript读取 textarea 的内容,并使用 marked 库将其转换为Markdown HTML,然后在 div 中显示。

在这里面使用的 https://cdn.jsdelivr.net/npm/marked/marked.min.js为MarkDown解释器的解析文件地址,如果无法使用有以下几种解决方式,我用的第一种,但是将地址更改了,CDN的解析地址可以自己再找一下,我是以下这个

html 复制代码
    <script src="https://unpkg.com/marked@13.0.2/marked.min.js"></script>

方法一:通过CDN引入

在HTML文件的 <head> 标签中添加以下脚本标签,从CDN加载 marked 库:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Textarea to Markdown</title>
    <script src="https://cdn.jsdelivr.net/npm/marked/marked.min.js"></script>
</head>
<body>
    <textarea style="font-size: 20px; width: 300px; height: 800px;" id="responseBox" name="responseBox" rows="4" cols="150" readonly>
# Example Markdown
This is an example of **Markdown** text.
- Item 1
- Item 2
    </textarea>
    <button onclick="convertToMarkdown()">Convert to Markdown</button>
    <div id="markdownDisplay"></div>

    <script>
        function convertToMarkdown() {
            var text = document.getElementById('responseBox').value;
            var markdownContent = marked(text);
            document.getElementById('markdownDisplay').innerHTML = markdownContent;
        }
    </script>
</body>
</html>

方法二:使用npm安装(适用于Node.js项目)

1.首先,通过npm安装 marked

html 复制代码
npm install marked

2.然后,在你的JavaScript文件中引入 marked

python 复制代码
const marked = require('marked');

// 示例代码
function convertToMarkdown() {
    var text = document.getElementById('responseBox').value;
    var markdownContent = marked(text);
    document.getElementById('markdownDisplay').innerHTML = markdownContent;
}

方法三:下载并本地引入

  • markedGitHub仓库 下载 marked.min.js 文件。

  • marked.min.js 文件放置在你的项目文件夹中,例如 js 文件夹。

  • 在HTML文件的 <head> 标签中添加本地路径的脚本标签:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Textarea to Markdown</title>
    <script src="js/marked.min.js"></script>
</head>
<body>
    <textarea style="font-size: 20px; width: 300px; height: 800px;" id="responseBox" name="responseBox" rows="4" cols="150" readonly>
# Example Markdown
This is an example of **Markdown** text.
- Item 1
- Item 2
    </textarea>
    <button onclick="convertToMarkdown()">Convert to Markdown</button>
    <div id="markdownDisplay"></div>

    <script>
        function convertToMarkdown() {
            var text = document.getElementById('responseBox').value;
            var markdownContent = marked(text);
            document.getElementById('markdownDisplay').innerHTML = markdownContent;
        }
    </script>
</body>
</html>
相关推荐
玩电脑的辣条哥2 小时前
Python如何播放本地音乐并在web页面播放
开发语言·前端·python
ew452183 小时前
ElementUI表格表头自定义添加checkbox,点击选中样式不生效
前端·javascript·elementui
suibian52353 小时前
AI时代:前端开发的职业发展路径拓宽
前端·人工智能
Moon.93 小时前
el-table的hasChildren不生效?子级没数据还显示箭头号?树形数据无法展开和收缩
前端·vue.js·html
垚垚 Securify 前沿站3 小时前
深入了解 AppScan 工具的使用:筑牢 Web 应用安全防线
运维·前端·网络·安全·web安全·系统安全
工业甲酰苯胺6 小时前
Vue3 基础概念与环境搭建
前端·javascript·vue.js
mosquito_lover17 小时前
怎么把pyqt界面做的像web一样漂亮
前端·python·pyqt
柴柴的小记9 小时前
前端vue引入特殊字体不生效
前端·javascript·vue.js
柠檬豆腐脑9 小时前
从前端到全栈:新闻管理系统及多个应用端展示
前端·全栈
bin915310 小时前
DeepSeek 助力 Vue 开发:打造丝滑的颜色选择器(Color Picker)
前端·javascript·vue.js·ecmascript·deepseek