在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文本并实现代码高亮了。记得根据项目的实际路径调整导入语句的路径。
网友回复
webgl与webgpu有啥不同?
Zero Trust的Tunnels怎么设置泛域名解析及http服务获取当前访问域名?
Spec Coding(规范驱动编码)和 Vibe Coding(氛围编程)有啥区别?
如何在国内服务器上正常运行未备案的域名网站?
Cloudflared 和WARP Connector有啥不同?
有没有让本地开源大模型越狱的方法或插件啥的?
如何使用Zero Trust的Tunnels技术将局域网电脑web服务可以公网访问呢?
编程领域ai大模型的排名是怎么样的?
如何修改别人发给我的微信笔记内容?
fbx、obj、glb三维格式模型如何在浏览器中通过three相互转换格式?


