激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務(wù)器之家 - 編程語言 - JavaScript - vue.js - Vue單頁面應(yīng)用中實(shí)現(xiàn)Markdown渲染

Vue單頁面應(yīng)用中實(shí)現(xiàn)Markdown渲染

2022-01-20 16:50YouXam vue.js

這篇文章主要介紹了Vue單頁面應(yīng)用中如何實(shí)現(xiàn)Markdown渲染,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下

之前渲染 Markdown 的時(shí)候, 筆者使用的是 mavonEditor 的預(yù)覽模式, 使用起來比較爽, 只需要引入組件即可, 但是在最近的開發(fā)中, 遇到了困難.

主要問題在于作為單頁面應(yīng)用, 站內(nèi)鏈接必須是使用 router-link 跳轉(zhuǎn), 如果使用 mavonEditor 默認(rèn)渲染的 a 標(biāo)簽, 就會重新加載頁面, 用戶體驗(yàn)較差.

動態(tài)渲染

想要實(shí)現(xiàn)在前端動態(tài)地根據(jù)用戶內(nèi)容渲染router-link , 需要使用動態(tài)渲染, 根據(jù) 官方文檔, 直接修改vue.config.js 即可:

?
1
2
3
4
// vue.config.js
module.exports = {
 runtimeCompiler: true
}

渲染 Markdown

筆者使用的是 markdown-it, 配置過程如下:

安裝

?
1
2
3
npm install markdown-it --save # 本體
npm install markdown-it-highlightjs --save # 代碼高亮
npm install markdown-it-katex --save # latex 支持

這里還另外安裝了兩個(gè)語法插件, 如果有其他需要的話, 可以在 npm 上搜索

靜態(tài)文件導(dǎo)入

highlight.js
通過 cdn 導(dǎo)入, 在 index.html 中加入:

?
1
2
<link rel="stylesheet" href="//cdn.jsdelivr.net/gh/highlightjs/[email protected]/build/styles/default.min.css" rel="external nofollow" >
<script src="//cdn.jsdelivr.net/gh/highlightjs/[email protected]/build/highlight.min.js"></script>

github-markdown-css

markdown 的樣式

安裝

?
1
npm install github-markdown-css --save

導(dǎo)入

在 main.js 文件中添加

?
1
import 'github-markdown-css/github-markdown.css'

katex

通過 cdn 導(dǎo)入, 在 index.html 中加入:

?
1
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.5.1/katex.min.css" rel="external nofollow" >

使用

首先在 components 目錄下創(chuàng)建 Markdown.vue 文件,

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
<template>
 <components :is="html" class="markdown-body"></components>
</template>
 
<script>
import MarkdownIt from 'markdown-it'
import hljs from 'markdown-it-highlightjs'
import latex from 'markdown-it-katex'
export default {
 name: 'Markdown',
 props: {
  content: String
 },
 data: () => ({
  md: null
 }),
 computed: {
  // 使用 computed 才能在動態(tài)綁定時(shí)動態(tài)更新
  html: function () {
   let res = this.md.render(this.content)
   // 使用正則表達(dá)式將站內(nèi)鏈接替換為 router-link 標(biāo)簽
   res = res.replace(/<a href="(?!http:\/\/|https:\/\/)(.*?)" rel="external nofollow" >(.*?)<\/a>/g, '<router-link to="$1">$2</router-link>')
   // 使用正則表達(dá)式將站外鏈接在新窗口中打開
   res = res.replace(/<a href="(.*?)" rel="external nofollow" >(.*?)<\/a>/g, '<a href="$1" rel="external nofollow" target="_blank">$2</a>')
   return {
    template: '<div>' + res + '</div>'
   }
  }
 },
 created () {
  this.md = new MarkdownIt()
  this.md.use(hljs).use(latex)
 }
}
</script>

然后在想使用的地方導(dǎo)入即可

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<template>
  <div>
    <Markdown :content="content"/>
  </div>
</template>
 
<script>
import Markdown from '@/components/Markdown.vue'
export default {
 name: 'Home',
 components: {
  Markdown
 },
 data: () => ({
  content: ''
 }),
 created () {
  this.content = '# 測試'
 }
}
</script>

以上就是Vue單頁面應(yīng)用中實(shí)現(xiàn)Markdown渲染的詳細(xì)內(nèi)容,更多關(guān)于vue Markdown渲染的資料請關(guān)注服務(wù)器之家其它相關(guān)文章!

原文鏈接:https://www.cnblogs.com/youxam/p/vue-markdown-render.html

延伸 · 閱讀

精彩推薦
  • vue.js詳解vue 表單綁定與組件

    詳解vue 表單綁定與組件

    這篇文章主要介紹了vue 表單綁定與組件的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下...

    Latteitcjz6432022-02-12
  • vue.jsVue項(xiàng)目中實(shí)現(xiàn)帶參跳轉(zhuǎn)功能

    Vue項(xiàng)目中實(shí)現(xiàn)帶參跳轉(zhuǎn)功能

    最近做了一個(gè)手機(jī)端系統(tǒng),其中遇到了父頁面需要攜帶參數(shù)跳轉(zhuǎn)至子頁面的問題,現(xiàn)已解決,下面分享一下實(shí)現(xiàn)過程,感興趣的朋友一起看看吧...

    YiluRen丶4302022-03-03
  • vue.js梳理一下vue中的生命周期

    梳理一下vue中的生命周期

    看過很多人講vue的生命周期,但總是被繞的云里霧里,尤其是自學(xué)的同學(xué),可能js的基礎(chǔ)也不是太牢固,聽起來更是吃力,那我就已個(gè)人之淺見,以大白話...

    CRMEB技術(shù)團(tuán)隊(duì)7992021-12-22
  • vue.jsVue2.x 項(xiàng)目性能優(yōu)化之代碼優(yōu)化的實(shí)現(xiàn)

    Vue2.x 項(xiàng)目性能優(yōu)化之代碼優(yōu)化的實(shí)現(xiàn)

    這篇文章主要介紹了Vue2.x 項(xiàng)目性能優(yōu)化之代碼優(yōu)化的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋...

    優(yōu)小U9632022-02-21
  • vue.jsVue中引入svg圖標(biāo)的兩種方式

    Vue中引入svg圖標(biāo)的兩種方式

    這篇文章主要給大家介紹了關(guān)于Vue中引入svg圖標(biāo)的兩種方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的...

    十里不故夢10222021-12-31
  • vue.js用vite搭建vue3應(yīng)用的實(shí)現(xiàn)方法

    用vite搭建vue3應(yīng)用的實(shí)現(xiàn)方法

    這篇文章主要介紹了用vite搭建vue3應(yīng)用的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下...

    Asiter7912022-01-22
  • vue.jsVue2.x-使用防抖以及節(jié)流的示例

    Vue2.x-使用防抖以及節(jié)流的示例

    這篇文章主要介紹了Vue2.x-使用防抖以及節(jié)流的示例,幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下...

    Kyara6372022-01-25
  • vue.jsVue多選列表組件深入詳解

    Vue多選列表組件深入詳解

    這篇文章主要介紹了Vue多選列表組件深入詳解,這個(gè)是vue的基本組件,有需要的同學(xué)可以研究下...

    yukiwu6752022-01-25
主站蜘蛛池模板: 国产一区二区在线免费 | 日本中文字幕电影在线观看 | 91精品国产777在线观看 | 欧美特一级片 | 成人三级电影网站 | 欧美一区在线观看视频 | 欧美成人精品一级 | 亚洲欧美不卡视频 | 成人毛片视频在线观看 | 欧美一级www片免费观看 | 91成人天堂久久成人 | 精品一区二区久久久久 | 久久久久久久免费看 | 日本不卡视频在线观看 | 国产精品视频在 | 蜜桃av网 | 免费在线成人网 | 欧美日韩在线播放 | 国产在线一级片 | 色999久久久精品人人澡69 | 亚洲综合一区二区三区 | 特级黄色一级毛片 | 多人乱大交xxxxx变态 | 一级在线免费观看视频 | 热@国产 | 视频一区二区三区在线播放 | 91情侣在线偷精品国产 | 奶子吧naiziba.cc免费午夜片在线观看 | 欧美片一区二区 | 久久网一区二区 | 在线日韩亚洲 | 国产一级伦理片 | a网站在线 | 国产va在线观看 | www.777含羞草| 国产精品一区在线看 | 久久久久久久久久久av | 久久久www成人免费毛片 | 爱草成年 | 操碰| 精品午夜影院 |