自己写一个Markdown解析器的最简单的html页面,方便gpt回复内容解析成你喜欢的样子

对于编程人员自然知道md,但是普通人估计就这不太清楚这些条条框框是干什么用的了,正好最近给大学写个脚本,类似通过AI批量出题的,通过表格中的课本章节和需求描述,然后批量根据表格中的每行数据调用gpt进行出题,由于gpt回复的虽然是有格式的,但其实是md格式,没办法整理到excel中进行使用,所以就需要md的解析器处理一下,然后就可以带格式复制到表格中用了。

效果如下:

左边输入md内容,右边自动显示解析后的内容,因为这个网页中ctrl+A会导致看的见的内容全部都会复制,为了方便加了一个复制全部解析内容的按钮。

一共就两个文件,一个是解析器的网页html文件,还有一个是md解析的marked插件的js,

一共就这样

解析器的marked.html代码如下:直接保存成.html格式就可以了。

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Markdown 转换器</title>
    <style>
        body {
            font-family: Arial, sans-serif;
        }
        .container {
            display: flex;
            justify-content: space-between;
            margin: 20px;
        }
        textarea {
            width: 45%;
            height: 400px;
            padding: 10px;
            font-size: 16px;
        }
        .output {
            width: 45%;
            height: 400px;
            padding: 10px;
            border: 1px solid #ccc;
            overflow-y: auto;
            background-color: #f9f9f9;
        }
        button {
            margin-top: 10px;
            padding: 10px 15px;
            font-size: 16px;
            cursor: pointer;
        }
    </style>
</head>
<body>

    <h1>Markdown 转换器</h1>

    <div class="container">
        <!-- Markdown 输入框 -->
        <textarea id="markdown-input" placeholder="在这里输入Markdown格式的内容..."></textarea>

        <!-- 解析后的 HTML 显示区域 -->
        <div id="html-output" class="output"></div>
    </div>

    <!-- 复制按钮 -->
    <div style="text-align: right;margin-right: 300px">
    <button id="copy-button">复制解析后的内容</button>
    </div>

    <!-- 引入本地 marked.min.js 文件 -->
    <script src="marked.min.js"></script>

    <script>
        const input = document.getElementById('markdown-input');
        const output = document.getElementById('html-output');
        const copyButton = document.getElementById('copy-button');

        // 当用户输入时,实时将 Markdown 转换为 HTML
        input.addEventListener('input', function() {
            const markdownText = input.value;
            const htmlContent = marked.parse(markdownText); // 使用 marked.js 解析 Markdown
            output.innerHTML = htmlContent;
        });

        // 点击按钮时复制解析后的内容
        copyButton.addEventListener('click', function() {
            // 创建一个临时元素来保存解析后的 HTML
            const tempTextArea = document.createElement('textarea');
            tempTextArea.value = output.innerHTML;  // 获取解析后的 HTML 内容
            document.body.appendChild(tempTextArea);
            tempTextArea.select();  // 选中内容
            document.execCommand('copy');  // 执行复制命令
            document.body.removeChild(tempTextArea);  // 移除临时元素
            alert('解析后的内容已复制到剪贴板!');  // 提示用户
        });
    </script>

</body>
</html>

至于marked.min.js文件正常网络好的情况下cdn直接引用就可以,但是很多教育网等等不太好用,下载的话在这个地址 https://cdn.jsdelivr.net/npm/marked/marked.min.js

html的文件的下载地址在这 marked.html

相关推荐
w(゚Д゚)w吓洗宝宝了2 小时前
单例模式 - 单例模式的实现与应用
开发语言·javascript·单例模式
zhaocarbon2 小时前
VUE elTree 无子级 隐藏展开图标
前端·javascript·vue.js
小周不摆烂3 小时前
探索JavaScript前端开发:开启交互之门的神奇钥匙(二)
javascript
匹马夕阳4 小时前
Vue 3中导航守卫(Navigation Guard)结合Axios实现token认证机制
前端·javascript·vue.js
我想学LINUX5 小时前
【2024年华为OD机试】 (A卷,100分)- 微服务的集成测试(JavaScript&Java & Python&C/C++)
java·c语言·javascript·python·华为od·微服务·集成测试
screct_demo5 小时前
詳細講一下在RN(ReactNative)中,6個比較常用的組件以及詳細的用法
javascript·react native·react.js
CodeClimb12 小时前
【华为OD-E卷 - 第k个排列 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
浪浪山小白兔13 小时前
HTML5 新表单属性详解
前端·html·html5
光头程序员14 小时前
grid 布局react组件可以循数据自定义渲染某个数据 ,或插入某些数据在某个索引下
javascript·react.js·ecmascript
fmdpenny15 小时前
Vue3初学之商品的增,删,改功能
开发语言·javascript·vue.js