溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么在vue中使用simplemde實(shí)現(xiàn)一個(gè)markdown編輯器

發(fā)布時(shí)間:2021-04-20 16:22:02 來源:億速云 閱讀:537 作者:Leah 欄目:web開發(fā)

怎么在vue中使用simplemde實(shí)現(xiàn)一個(gè)markdown編輯器?相信很多沒有經(jīng)驗(yàn)的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。

為什么要使用Vue

Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以創(chuàng)建可維護(hù)性和可測試性更強(qiáng)的代碼庫,Vue允許可以將一個(gè)網(wǎng)頁分割成可復(fù)用的組件,每個(gè)組件都包含屬于自己的HTML、CSS、JavaScript,以用來渲染網(wǎng)頁中相應(yīng)的地方,所以越來越多的前端開發(fā)者使用vue。

安裝及初始化

npm install simplemde --save

在html中加入一個(gè)textarea

<textarea id="simplemde"></textarea>

在vue的生命周期函數(shù) mounted 中,添加 simplemde 的實(shí)例化

var simplemde = new SimpleMDE({
   el: document.getElementById(simplemde)
  })

el 通過dom指定為我們建立的textarea元素,如果省略,則會自動抓取html結(jié)構(gòu)中的第一個(gè)textarea

綁定事件,使我們的內(nèi)容數(shù)據(jù)始終與 simplemde 獲取到的鍵入數(shù)據(jù)同步

simplemde.codemirror.on("change", () => {
   this.content = simplemde.value()
  })

上傳圖片

在原本的 simplemde 中

點(diǎn)擊圖片按鈕的效果是這樣的

怎么在vue中使用simplemde實(shí)現(xiàn)一個(gè)markdown編輯器

這是個(gè)啥??本地上傳的選擇框呢??

沒辦法,既然沒有就只好自己做一個(gè)了

首先我們建立一個(gè)隱藏的 input

<input  accept="image/gif,image/jpeg,image/jpg,image/png" type="file" id="upInput" ref="upInput">

接收圖片格式的文件,點(diǎn)擊即可彈出本地上傳的文件選擇框

之所以要隱藏,是因?yàn)槲覀儾⒉幌胍@個(gè)按鈕

我們還是想通過點(diǎn)擊 simplemde 的圖片按鈕來上傳

雖然人家沒啥用,但好看呀

所以我們就把這個(gè) input 給隱藏,只用一下它的 click 方法

這樣我們點(diǎn)擊圖片按鈕就相當(dāng)于在點(diǎn)擊這個(gè) input

在 simplemde 的源碼里,找到圖片按鈕調(diào)用的函數(shù)

把原來的都注釋掉,加上這兩句

怎么在vue中使用simplemde實(shí)現(xiàn)一個(gè)markdown編輯器

這樣我們就可以調(diào)用本地上傳的選擇框了

怎么在vue中使用simplemde實(shí)現(xiàn)一個(gè)markdown編輯器

那么選擇了圖片之后,為了能即時(shí)預(yù)覽

我們希望選擇之后,就發(fā)到后端存儲起來

在前端我們運(yùn)用 axios + formdata 進(jìn)行發(fā)送

var input = this.$refs.upInput
var formData = new FormData()
formData.append("i", input.files[0])
var config = {
   headers: {
    "Content-Type": "multipart/form-data"
   }
  }
this.$axios.post("/data/myupload", formData, config)

后端我是用的 node ,運(yùn)用 multer 模塊來接收

multer 是專門用來處理 mulipart/form-data 格式的數(shù)據(jù)的

var multer = require('multer')
    //定義存儲器
  var storage = multer.diskStorage({
  //存儲路徑
  destination: function (req, file, cb) {
    cb(null, '../static/upload/')
  },
  //存儲文件名
  filename: function (req, file, cb) {
    cb(null, `${Date.now()}-${file.originalname}`)
  }
  })
  //運(yùn)用存儲器
  var upload = multer({ storage: storage })

  // 接受單圖的上傳
  router.post('/data/myupload', upload.single('i'), function (req,  res, next) {
  //將存儲后的文件名發(fā)還給前端
  res.send(req.file.filename)
  });

前端收到文件名后,將其跟存儲路徑打包寫進(jìn)文本框中

也就是之前點(diǎn)擊圖片按鈕看到的那串字符

寫入后就可預(yù)覽

this.$axios.post("/data/myupload", formData, config).then((res)=> {
  var urlname=`![](/static/upload/${res.data})`
  simplemde.value(`${this.content}\n${urlname}\n`)
 })

看起來萬事大吉了

但其實(shí)還漏了一點(diǎn)

那就是input的click()本身不是異步的,但是你選擇圖片需要時(shí)間,在這過程中后面的代碼(即便是異步代碼)都執(zhí)行了一遍,也就是說現(xiàn)在寫的這些發(fā)送存儲都在選完圖片之前就執(zhí)行完了

為了在選擇完圖片之后再執(zhí)行

我們新增一個(gè)監(jiān)聽事件,監(jiān)聽 input 的 change ,把之前的代碼都丟到這里面來

var input = this.$refs.upInput
input.addEventListener("change", () => {
 var formData = new FormData()
 formData.append("i", input.files[0])
 var config = {
  headers: {
   "Content-Type": "multipart/form-data"
  }
 }
 this.$axios.post("/data/myupload", formData, config).then((res)=> {
  var urlname=`![](/static/upload/${res.data})`
  simplemde.value(`${this.content}\n${urlname}\n`)
 })
})

這樣就實(shí)現(xiàn)了我們的圖片上傳效果

顯示

比如通過編輯器,我們寫了一篇博客,并存儲進(jìn)了后臺

想在別的組件中把它調(diào)出來顯示

也就是字符串轉(zhuǎn)為html

只需要調(diào)用 simplemde 的原型鏈方法

this.contentMarkdown = SimpleMDE.prototype.markdown(content)

然后把數(shù)據(jù)放到v-html中

<div v-html="contentMarkdown"></div>

看完上述內(nèi)容,你們掌握怎么在vue中使用simplemde實(shí)現(xiàn)一個(gè)markdown編輯器的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI