vue-cli3项目展示本地Markdown文件的方法


Posted in Javascript onJune 07, 2019

【版本】

  • vue-cli3
  • webpack@4.33.0

【步骤】1、安装插件vue-markdown-loader

npm i vue-markdown-loader -D

ps:这个插件是基于markdown-it的,不需要单独安装markdown-it。

2、修改vue.config.js配置文件(如果没有,在项目根目录新建一个):

module.exports = {
 chainWebpack: config => {
  config.module.rule('md')
   .test(/\.md/)
   .use('vue-loader')
   .loader('vue-loader')
   .end()
   .use('vue-markdown-loader')
   .loader('vue-markdown-loader/lib/markdown-compiler')
   .options({
    raw: true
   })
 }
}

3、直接上代码

App.vue

<template>
 <my-markdown></my-markdown>
</template>

<script>
import myMarkdown from './assets/cpu.md';
export default {
 components: {
  myMarkdown
 },
</script>

正常情况下,到这里就结束了。

【坑】

由于业务给我的Markdown文档的标题是这样的:

##物理CPU个数
物理CPU数就是主板上实际插入的CPU数量
……

得到的结果并不让我满意:

vue-cli3项目展示本地Markdown文件的方法

折腾了大半天才发现,这是由于标题的#井号和文字之间没有空格导致的。证明见下:

var MarkdownIt = require('markdown-it'),
md = new MarkdownIt();
console.log(md.render('# markdown-it rulezz!'))//<h1>markdown-it rulezz!</h1>
console.log(md.render('#markdown-it rulezz!'))//<p>#markdown-it rulezz!</p>

Fine :)

愚蠢的我想出了一个解决办法:

因为HyperDown.js能避免上面那样的情况,于是我用它来对文档做预处理。

安装HyperDown.js

npm install hyperdown -D

然后把vue.config.js改成了这样。

let HyperDown = require('hyperdown');
let parser = new HyperDown;

module.exports = {
 chainWebpack: config => {
  config.module.rule('md')
   .test(/\.md/)
   .use('vue-loader')
   .loader('vue-loader')
   .end()
   .use('vue-markdown-loader')
   .loader('vue-markdown-loader/lib/markdown-compiler')
   .options({
    // markdown-it config
    preset: 'default',
    breaks: true,
    raw: true,
    typographer: true,
    preprocess: function(markdownIt, source) {
     return parser.makeHtml(source);//重点在这里!!!
    }
   })
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javaScript 判断字符串是否为数字的简单方法
Jul 25 Javascript
extjs 学习笔记 四 带分页的grid
Oct 20 Javascript
JS截取字符串常用方法详细整理
Oct 28 Javascript
js和jquery中循环的退出和继续学习记录
Sep 06 Javascript
jQuery获取attr()与prop()属性值的方法及区别介绍
Jul 06 Javascript
js中删除数组中的某一元素实例(无下标时)
Feb 28 Javascript
webpack打包js的方法
Mar 12 Javascript
详解vue-cli3使用
Aug 14 Javascript
详解element-ui中表单验证的三种方式
Sep 18 Javascript
vue页面切换项目实现转场动画的方法
Nov 12 Javascript
VsCode里的Vue模板的实现
Aug 12 Javascript
idea编译器vue缩进报错问题场景分析
Jul 04 Vue.js
Element实现表格分页数据选择+全选所有完善批量操作
Jun 07 #Javascript
详解vue项目中实现图片裁剪功能
Jun 07 #Javascript
sortable+element 实现表格行拖拽的方法示例
Jun 07 #Javascript
利用Vue-draggable组件实现Vue项目中表格内容的拖拽排序
Jun 07 #Javascript
Vue中实现权限控制的方法示例
Jun 07 #Javascript
vue 父组件中调用子组件函数的方法
Jun 06 #Javascript
通过seajs实现JavaScript的模块开发及按模块加载
Jun 06 #Javascript
You might like
PHP 高手之路(一)
2006/10/09 PHP
WindowsXP中快速配置Apache+PHP5+Mysql
2008/06/05 PHP
PHP获取url的函数代码
2011/08/02 PHP
ThinkPHP之getField详解
2014/06/20 PHP
php经典算法集锦
2015/11/14 PHP
PHP获取路径和目录的方法总结【必看篇】
2017/03/04 PHP
使用composer安装使用thinkphp6.0框架问题【视频教程】
2019/10/01 PHP
php使用redis的有序集合zset实现延迟队列应用示例
2020/02/20 PHP
TP5多入口设置实例讲解
2020/12/15 PHP
JS 动态加载脚本的4种方法
2009/05/05 Javascript
jqGrid增加时--判断开始日期与结束日期(实例解析)
2013/11/08 Javascript
Javascript获取当前日期的农历日期代码
2014/10/08 Javascript
简介JavaScript中用于处理正切的Math.tan()方法
2015/06/15 Javascript
JS实现可关闭的对联广告效果代码
2015/09/14 Javascript
JS+CSS实现简易实用的滑动门菜单效果
2015/09/18 Javascript
js下载文件并修改文件名
2017/05/08 Javascript
微信小程序的分类页面制作
2017/06/27 Javascript
vscode下vue项目中eslint的使用方法
2019/01/13 Javascript
小程序简单两栏瀑布流效果的实现
2019/12/18 Javascript
Vue自定义组件双向绑定实现原理及方法详解
2020/09/03 Javascript
vue2.0 watch里面的 deep和immediate用法说明
2020/10/30 Javascript
Python根据区号生成手机号码的方法
2015/07/08 Python
python执行系统命令后获取返回值的几种方式集合
2018/05/12 Python
对matplotlib改变colorbar位置和方向的方法详解
2018/12/13 Python
django一对多模型以及如何在前端实现详解
2019/07/24 Python
python双向链表原理与实现方法详解
2019/12/03 Python
python识别验证码图片实例详解
2020/02/17 Python
Python 中Operator模块的使用
2021/01/30 Python
Html5定位终极解决方案
2020/02/05 HTML / CSS
世界上最大的高分辨率在线图片库:Alamy
2018/07/07 全球购物
澳洲CFL商城:CHEMIST FOR LESS(中文)
2021/02/28 全球购物
高中考试作弊检讨书
2014/01/14 职场文书
代理商会议邀请函
2014/01/27 职场文书
优秀公益广告词大全
2014/03/19 职场文书
父亲节活动总结
2015/02/12 职场文书
go goroutine 怎样进行错误处理
2021/07/16 Golang