前端解析markdown处理表格样式

后端返回markdown格式,前端解析,使用的是marked.js
安装

npm install marked --save

另外我也给代码做了高亮

npm install highlight.js --save

main.js

import hljs from 'highlight.js';
//封装成一个指令,highlight是指令的名称
Vue.directive('highlight', (el) => {
  let blocks = el.querySelectorAll('pre code')
  blocks.forEach((block) => {
    // 创建ol标签元素
    let ol = document.createElement("ol");
    block.parentNode.appendChild(ol);

    hljs.highlightBlock(block)
})

chatGpt.vue

 // html部分
<div class="detail" v-highlight v-html="answer"></div>
//js部分
import { marked } from 'marked';
// 引入代码高亮样式
import 'highlight.js/styles/darcula.css';

// res.data为后端返回的markdown格式的信息
this.answer = marked(res.data)

表格部分直接解析没有线条,我自己写了table的样式

   ::v-deep XXXXX{   
        table {
              border: 1px solid #ccc;
            }
            table td,
            table th {
              border-bottom: 1px solid #ccc;
              border-right: 1px solid #ccc;
              padding: 5px 10px;
            }
            table th {
              // border-bottom: 2px solid #ccc;
              text-align: center;
              background: #dee8ee;
            }
            table th:last-child {
              border-right: none;
            }
            table td:last-child {
              border-right: none;
            }

            table tr:last-child td {
              border-bottom: none;
            }
            tr:nth-child(even) {
              background: #eff3f5;
            }
            /* blockquote 样式 */
            blockquote {
              display: block;
              border-left: 8px solid #d0e5f2;
              padding: 5px 10px;
              margin: 10px 0;
              line-height: 1.4;
              font-size: 100%;
              background-color: #f1f1f1;
            }
 /* ul ol 样式 */
            ul,
            ol {
              margin: 10px 0 10px 20px;
            }
          }
}
posted @ 2023-05-24 17:47  sinceForever  阅读(947)  评论(1编辑  收藏  举报