+
90
-

回答

在uni-app中渲染Markdown文本并实现代码高亮,可以使用marked库结合highlight.js库来实现。以下是具体的实现步骤:

安装依赖:首先需要安装marked和highlight.js库。在项目的根目录下运行以下命令来安装这些依赖:

npm install marked
npm install highlight.js

配置marked:在需要渲染Markdown的组件中,导入marked和highlight.js,并配置marked以使用highlight.js进行代码高亮:

import { marked } from 'marked';
import hljs from 'highlight.js';

marked.setOptions({
  renderer: new marked.Renderer(),
  highlight: function (code, lang) {
    if (lang && hljs.getLanguage(lang)) {
      return hljs.highlight(lang, code).value;
    } else {
      return hljs.highlightAuto(code).value;
    }
  },
  pedantic: false,
  gfm: true,
  tables: true,
  breaks: false,
  sanitize: false,
  smartLists: true,
  smartypants: false,
  xhtml: false
});

渲染Markdown:在组件的data中定义一个变量来存储Markdown文本,然后在mounted生命周期钩子中使用marked解析Markdown文本,并更新一个变量来存储渲染后的HTML:

export default {
  data() {
    return {
      markdownText: '# Hello Markdown\n\nThis is a markdown preview.',
      htmlContent: ''
    };
  },
  mounted() {
    this.htmlContent = marked(this.markdownText);
  }
};

在模板中使用:在组件的模板中,使用v-html指令来将渲染后的HTML内容绑定到一个元素上:

<template>
  <view v-html="htmlContent"></view>
</template>

样式调整:可以根据需要引入highlight.js的样式文件,以确保代码块有合适的样式:

import 'highlight.js/styles/default.css'; // 或者选择其他你喜欢的主题

这样,就可以在uni-app项目中渲染Markdown文本并实现代码高亮了。记得根据项目的实际路径调整导入语句的路径。

网友回复

我知道答案,我要回答