vue3 项目构建-8-展示 markdown 文档

第一步,下载插件

复制代码
npm install markdown-it

第二步,使用插件渲染

javascript 复制代码
<template>
  <div v-html="htmlContent"></div>
</template>

<script setup>
import { ref, computed } from 'vue';
import MarkdownIt from 'markdown-it';
// 创建 MarkdownIt 实例
const md = new MarkdownIt();
// 定义一个响应式的 Markdown 文本
const markdownText = ref('# Hello, World!\nThis is a markdown paragraph in script setup.');
// 通过计算属性将 Markdown 文本转换为 HTML 内容
const htmlContent = computed(() => md.render(markdownText.value));
</script>

实际页面的应用:

javascript 复制代码
<script setup>
import { inject, onMounted, ref, computed, watch } from 'vue';
import MarkdownIt from 'markdown-it';
const axios = inject('$axios');
const view = ref([]);
const getPostArticleView = async () => {
    const res = await axios({
        method: 'post',
        url: '/articles/view/1',
    });
    view.value = res.data.data;
    console.log(view);
};

let hasExecuted = false;

onMounted(() => {
    if (!hasExecuted) {
        getPostArticleView();
        hasExecuted = true;
    }
});

const md = new MarkdownIt();
// 用于存储转换后的HTML内容,初始为空
const htmlContent = ref('');
watch(view, (newView) => {
    if (newView && newView.body && newView.body.content) {
        // 当view有有效数据时,进行Markdown转换
        htmlContent.value = md.render(newView.body.content);
    }
}, { immediate: false });
</script>

<template>
    <div id="article">
        <div class="textSpring">
            <h1>{{view.title}}</h1>
            <hr>
            <div v-html="htmlContent"></div>
        </div>
    </div>
</template>

<style scoped>
    #article{
        padding: 20px;
    }

    .textSpring{
        margin: 0 auto;
        border: 1px solid black;
        border-radius: 5px;
        width: 60%;
    }
</style>

文章封面:

相关推荐
亭上秋和景清1 分钟前
指针进阶: 回调函数
开发语言·前端·javascript
前端小臻3 分钟前
react中的函数组件和类组件(快捷指令和区别)
前端·react.js·前端框架
烤麻辣烫5 分钟前
黑马大事件学习-15(前端登录页面)
前端·css·vue.js·学习·html
Cache技术分享13 分钟前
266. Java 集合 - ArrayList vs LinkedList 内存使用深度剖析
前端·后端
豆苗学前端18 分钟前
彻底讲透浏览器的事件循环,吊打面试官
前端·javascript·面试
来自上海的这位朋友19 分钟前
从零打造一个无依赖的Canvas图片编辑器
javascript·vue.js·canvas
OpenTiny社区29 分钟前
揭秘!TinyEngine低代码源码如何玩转双向转换?
前端·vue.js·低代码
用户81686947472530 分钟前
beginWork 与 completeWork 的内部职责分工
前端·react.js
3秒一个大33 分钟前
从后端模板到响应式驱动:界面开发的演进之路
前端·后端
三喵22335 分钟前
跨域 iframe 内嵌的同源策略适配方案-Youtube举例
前端·爬虫