国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

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

服務器之家 - 編程語言 - JavaScript - vue.js - Vue單頁面應用中實現Markdown渲染

Vue單頁面應用中實現Markdown渲染

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

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

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

主要問題在于作為單頁面應用, 站內鏈接必須是使用 router-link 跳轉, 如果使用 mavonEditor 默認渲染的 a 標簽, 就會重新加載頁面, 用戶體驗較差.

動態渲染

想要實現在前端動態地根據用戶內容渲染router-link , 需要使用動態渲染, 根據 官方文檔, 直接修改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 支持

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

靜態文件導入

highlight.js
通過 cdn 導入, 在 index.html 中加入:

?
1
2
<link rel="stylesheet" href="//cdn.jsdelivr.net/gh/highlightjs/cdn-release@10.5.0/build/styles/default.min.css" rel="external nofollow" >
<script src="//cdn.jsdelivr.net/gh/highlightjs/cdn-release@10.5.0/build/highlight.min.js"></script>

github-markdown-css

markdown 的樣式

安裝

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

導入

在 main.js 文件中添加

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

katex

通過 cdn 導入, 在 index.html 中加入:

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

使用

首先在 components 目錄下創建 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 才能在動態綁定時動態更新
  html: function () {
   let res = this.md.render(this.content)
   // 使用正則表達式將站內鏈接替換為 router-link 標簽
   res = res.replace(/<a href="(?!http:\/\/|https:\/\/)(.*?)" rel="external nofollow" >(.*?)<\/a>/g, '<router-link to="$1">$2</router-link>')
   // 使用正則表達式將站外鏈接在新窗口中打開
   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>

然后在想使用的地方導入即可

?
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單頁面應用中實現Markdown渲染的詳細內容,更多關于vue Markdown渲染的資料請關注服務器之家其它相關文章!

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

延伸 · 閱讀

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

    詳解vue 表單綁定與組件

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

    Latteitcjz6432022-02-12
  • vue.jsVue項目中實現帶參跳轉功能

    Vue項目中實現帶參跳轉功能

    最近做了一個手機端系統,其中遇到了父頁面需要攜帶參數跳轉至子頁面的問題,現已解決,下面分享一下實現過程,感興趣的朋友一起看看吧...

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

    梳理一下vue中的生命周期

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

    CRMEB技術團隊7992021-12-22
  • vue.jsVue2.x 項目性能優化之代碼優化的實現

    Vue2.x 項目性能優化之代碼優化的實現

    這篇文章主要介紹了Vue2.x 項目性能優化之代碼優化的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋...

    優小U9632022-02-21
  • vue.jsVue中引入svg圖標的兩種方式

    Vue中引入svg圖標的兩種方式

    這篇文章主要給大家介紹了關于Vue中引入svg圖標的兩種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的...

    十里不故夢10222021-12-31
  • vue.js用vite搭建vue3應用的實現方法

    用vite搭建vue3應用的實現方法

    這篇文章主要介紹了用vite搭建vue3應用的實現方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下...

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

    Vue2.x-使用防抖以及節流的示例

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

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

    Vue多選列表組件深入詳解

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

    yukiwu6752022-01-25
主站蜘蛛池模板: 久久av网 | 国产精品第一国产精品 | 成人av影视 | 国产玖玖 | 91av亚洲| 99久久精品国产一区二区三区 | 91久久综合亚洲鲁鲁五月天 | 在线精品日韩 | 亚洲高清一区二区三区 | 国产精品久久久久久久一区探花 | 欧美成人精品一区二区男人看 | 免费一区二区三区四区 | 亚洲一区二区三区高清 | 欧美午夜影院 | 亚洲精品99| 秋霞特色aa大片 | 伊人精品成人久久综合软件 | 成人高清视频在线 | 依人成人综合网 | 中文久久 | 99久久视频| 黄小视频 | www.久久久久久久 | 日韩成人免费中文字幕 | 欧美专区在线 | 日韩国产高清在线 | 欧美片网站免费 | av电影在线免费 | 亚洲国产高清视频 | 欧美va视频| 亚洲国产精品成人 | 亚洲福利 | 精品无码久久久久久久动漫 | 三级视频在线观看 | 国产日韩一区二区三区 | 亚洲第一福利视频 | 亚洲一区久久 | 91亚洲日本| 欧美一区二区在线视频 | 日韩有码在线视频 | 日本福利在线观看 |