vue导入.md文件的步骤(markdown转HTML)


Posted in Vue.js onDecember 31, 2020

前言

刚接到这个需求的时候,觉得很简单(的确很简单)但是这玩意的坑真的也让人无奈。

网上找了很多的资料,都没有写出痛点(这就很难过了)。通过实践并且在我们项目中平稳运行,想分享给后面的人

我的博客上也写了100多篇文章,点击量有上万的也有个位数的,能够帮助到他人这就是写作记录的动力。

需求

vue项目中可以良好展示markdown(只是展示功能 没有编辑功能)

痛点问题

  1. .md文件类型,直接模块加载(只有字符串,这得多难受,怎么维护呢),还是一个文件一个文件的好维护并且好修改复用
  2. 用第三方插件,只是md转HTML,不带样式的(重点强调 没有样式没有样式)

解决方案

一、vue需要有markdown这样良好的展示效果,什么样的插件是最好的?

货比三家,我推荐以下方式

//安装
npm install --save html-loader;
npm install -- save markdown-loader;

//webpack
 {
   test: /\.md$/,
   loader: "html-loader",
 },
 {
   test: /\.md$/,
   loader: "markdown-loader"
 }

大坑预警:我不知道在哪里抄的配置,一定不要配置option(配置了的话表格 代码 都不能好好转化)

以上真的就完成了转化了。是不是so easy !!! 再来换个皮肤(穿上衣服)

二、一定要引用CSS,找了很多样式真的都特别的丑(当然可以自己写,但是费时间啊)

强烈推荐

npm install github-markdown-css
import 'github-markdown-css'; //哪里用markdown 就在哪里引用 可以放在min.js

//自己也可以再调整调整 (贡献一版 我们调整的一版样式)
.markdown-body {
 padding: 20px;
 min-width: 200px;
 max-width: 900px;
 font-size: 12px;
 h2 {
 font-size: 18px;
 margin: 1em 0 15px;
 padding-top: 0.8em;
 padding-bottom: 0.8em;
 }
 h3 {
 font-size: 14px;
 margin: 22px 0 16px;
 }
 h4 {
 font-size: 13px;
 margin: 20px 0 16px;
 }
 h5 {
 font-size: 12px;
 margin: 16px 0 16px;
 font-weight: 700;
 }
 p {
 font-size: 12px;
 line-height: 24px;
 color: #666666;
 margin-top: 0px;
 margin: 8px 0;
 margin: 14px 0 14px;
 }
 pre {
 background-color: #eee;
 margin-bottom: 8px;
 margin-top: 8px;
 margin: 12px 0 12px;
 }
 blockquote {
 margin-bottom: 8px;
 margin-top: 8px;
 margin: 14px 0 14px;
 background-color: #eee;
 padding: 16px 16px;
 }
 tr {
 background-color: #f5f5f5;
 }
 code {
 background-color: #eee;
 }
 ul,
 ol,
 li {
 list-style: unset;
 font-size: 12px;
 line-height: 20px;
 color: #666666;
 margin-top: 0px;
 margin: 8px 0;
 }
 blockquote {
 border-color: #48b6e2;
 }
 table {
 display: table;
 width: 100%;
 max-width: 100%;
 margin-bottom: 20px;
 }
}

三、页面运用(实践检验真理)

页面
<template>
 <div class="markdown-body" v-html="htmlMD"></div> //markdown-body 一定要写这个class名
</template>

<script>
export default {
 name: 'GitBook',
 data() {
 return {
  htmlMD: ''
 };
 },
 mounted() {
 this.getHtmlMD(this.$route.query.databaseType);
 },
 methods: {
 getHtmlMD(type) {
  this.htmlMD = require(`./GitBook/${type.toLowerCase()}.md`); //导入md 我这里根据不同的类型拿不同md文件
 }
 }
};
</script>

四、最终效果 (表格,代码(缩进完全没有问题)我懒的去写一个实例了)打码勿怪

vue导入.md文件的步骤(markdown转HTML)

以上就是vue导入.md文件的步骤(markdown转HTML)的详细内容,更多关于vue 导入.md文件的资料请关注三水点靠木其它相关文章!

Vue.js 相关文章推荐
详解vue 组件注册
Nov 20 Vue.js
Vue router传递参数并解决刷新页面参数丢失问题
Dec 02 Vue.js
用vue设计一个日历表
Dec 03 Vue.js
全面解析Vue中的$nextTick
Dec 24 Vue.js
vue 使用rules对表单字段进行校验的步骤
Dec 25 Vue.js
vue中父子组件的参数传递和应用示例
Jan 04 Vue.js
如何理解Vue前后端数据交互与显示
May 10 Vue.js
vue+element ui实现锚点定位
Jun 29 Vue.js
详细聊聊vue中组件的props属性
Nov 02 Vue.js
vue实现滑动解锁功能
Mar 03 Vue.js
Vue.Draggable实现交换位置
Apr 07 Vue.js
vue生命周期钩子函数以及触发时机
Apr 26 Vue.js
vue-cli4.0多环境配置变量与模式详解
Dec 30 #Vue.js
基于Vue3.0开发轻量级手机端弹框组件V3Popup的场景分析
Dec 30 #Vue.js
SpringBoot+Vue 前后端合并部署的配置方法
Dec 30 #Vue.js
vue中实现点击空白区域关闭弹窗的两种方法
Dec 30 #Vue.js
梳理一下vue中的生命周期
Dec 30 #Vue.js
Vue实现简易购物车页面
Dec 30 #Vue.js
利用Vue实现简易播放器的完整代码
Dec 30 #Vue.js
You might like
咖啡豆的最常见发酵处理方法,详细了解一下
2021/03/03 冲泡冲煮
PHP简单系统数据添加以及数据删除模块源文件下载
2008/06/07 PHP
php清空(删除)指定目录下的文件,不删除目录文件夹的实现代码
2014/09/04 PHP
PHP中使用Session配合Javascript实现文件上传进度条功能
2014/10/15 PHP
Laravel中使用自己编写类库的3种方法
2015/02/10 PHP
PHP培训要多少钱
2017/06/06 PHP
一个tab标签切换效果代码
2009/03/27 Javascript
javascript入门基础之私有变量
2010/02/23 Javascript
eval的两组性能测试数据
2012/08/17 Javascript
JavaScript数据类型判定的总结笔记
2015/07/31 Javascript
实例讲解jquery中mouseleave和mouseout的区别
2016/02/17 Javascript
jQuery实现轮播图及其原理详解
2020/04/12 jQuery
微信小程序中this.data与this.setData的区别详解
2018/09/17 Javascript
Vue + element 实现多选框组并保存已选id集合的示例代码
2020/06/03 Javascript
Python获取Linux系统下的本机IP地址代码分享
2014/11/07 Python
Python中的面向对象编程详解(上)
2015/04/13 Python
Python连接mysql数据库的正确姿势
2016/02/03 Python
浅谈Python由__dict__和dir()引发的一些思考
2017/10/30 Python
Django实现学生管理系统
2019/02/26 Python
Python正则表达式匹配日期与时间的方法
2019/07/07 Python
Python OrderedDict的使用案例解析
2019/10/25 Python
利用Python校准本地时间的方法教程
2019/10/31 Python
如何在python中实现随机选择
2019/11/02 Python
Python 过滤错误log并导出的实例
2019/12/26 Python
pytorch中的自定义反向传播,求导实例
2020/01/06 Python
pytorch 实现删除tensor中的指定行列
2020/01/13 Python
500行python代码实现飞机大战
2020/04/24 Python
汤米巴哈马官方网站:Tommy Bahama
2017/05/13 全球购物
优秀毕业大学生推荐信
2013/11/13 职场文书
大学自我鉴定
2013/12/20 职场文书
中学生英语演讲稿
2014/04/26 职场文书
师德师风个人反思
2014/04/28 职场文书
2014年企业党建工作总结
2014/12/18 职场文书
2015年个人剖析材料范文
2014/12/29 职场文书
Nginx同一个域名配置多个项目的实现方法
2021/03/31 Servers
PHP 技巧 * SVG 保存为图片(分享图生成)
2021/04/02 PHP