欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue中利用simplemde實現(xiàn)markdown編輯器(增加圖片上傳功能)

 更新時間:2019年04月29日 08:40:13   作者:夜行風(fēng)  
這篇文章主要介紹了vue中利用simplemde實現(xiàn)markdown編輯器(增加圖片上傳功能),本文通過實例代碼相結(jié)合的形式給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下

前言

最近在搭個人博客網(wǎng)站,需要一個 markdown 編輯器,來進行博客的編寫

看了網(wǎng)上的教程,決定使用 simplemde

以為可以直接能拿來用的

不過實際運用的時候發(fā)現(xiàn)還是有要完善的地方

比如令人頭疼的圖片上傳

最終效果

 

安裝及初始化

npm install simplemde --save

在html中加入一個textarea

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

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

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

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

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

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

上傳圖片

在原本的 simplemde 中

點擊圖片按鈕的效果是這樣的


這是個啥??本地上傳的選擇框呢??

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

首先我們建立一個隱藏的 input

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

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

之所以要隱藏,是因為我們并不想要這個按鈕

我們還是想通過點擊 simplemde 的圖片按鈕來上傳

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

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

這樣我們點擊圖片按鈕就相當于在點擊這個 input

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

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


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


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

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

在前端我們運用 axios + formdata 進行發(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 ,運用 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}`)
  }
  })
  //運用存儲器
  var upload = multer({ storage: storage })

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

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

也就是之前點擊圖片按鈕看到的那串字符

寫入后就可預(yù)覽

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

看起來萬事大吉了

但其實還漏了一點

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

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

我們新增一個監(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`)
 })
})

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

顯示

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

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

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

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

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

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

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

即可顯示

再看一遍最終效果

PS

還有一些可以完善的地方

比如直接拖拽圖片進來,或者粘貼

后期有時間研究一下再加上

總結(jié)

以上所述是小編給大家介紹的vue中利用simplemde實現(xiàn)markdown編輯器(增加圖片上傳功能),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • vue 雙向數(shù)據(jù)綁定的實現(xiàn)學(xué)習(xí)之監(jiān)聽器的實現(xiàn)方法

    vue 雙向數(shù)據(jù)綁定的實現(xiàn)學(xué)習(xí)之監(jiān)聽器的實現(xiàn)方法

    這篇文章主要介紹了vue 雙向數(shù)據(jù)綁定的實現(xiàn)學(xué)習(xí)之監(jiān)聽器的實現(xiàn)方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-11-11
  • vue文件批量上傳及進度條展示的實現(xiàn)方法

    vue文件批量上傳及進度條展示的實現(xiàn)方法

    開發(fā)項目的時候,用到文件上傳的功能很常見,包括單文件上傳和多文件上傳,下面這篇文章主要給大家介紹了關(guān)于vue文件批量上傳及進度條展示的實現(xiàn)方法,需要的朋友可以參考下
    2022-12-12
  • vue+canvas實現(xiàn)移動端手寫簽名

    vue+canvas實現(xiàn)移動端手寫簽名

    這篇文章主要為大家詳細介紹了vue+canvas實現(xiàn)移動端手寫簽名,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • Nuxt.js結(jié)合Serverless構(gòu)建無服務(wù)器應(yīng)用

    Nuxt.js結(jié)合Serverless構(gòu)建無服務(wù)器應(yīng)用

    Nuxt.js是一個基于Vue.js的框架,結(jié)合Serverless架構(gòu),Nuxt.js可以讓你構(gòu)建高度可擴展、成本效益高的無服務(wù)器應(yīng)用,具有一定的參考價值,感興趣的可以了解一下
    2024-08-08
  • vue項目實現(xiàn)圖片上傳功能

    vue項目實現(xiàn)圖片上傳功能

    這篇文章主要為大家詳細介紹了vue項目實現(xiàn)圖片上傳功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • Vue路由配置方法詳細介紹

    Vue路由配置方法詳細介紹

    Vue3和Vue2基本差不多,只不過需要將createRouter、createWebHistory從vue-router中引入,再進行使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-09-09
  • 在Vue mounted方法中使用data變量詳解

    在Vue mounted方法中使用data變量詳解

    今天小編就為大家分享一篇在Vue mounted方法中使用data變量詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • 一篇文章帶你了解vue路由

    一篇文章帶你了解vue路由

    這篇文章主要為大家詳細介紹了vue的路由,路由的本質(zhì)就是一種對應(yīng)關(guān)系,比如說我們在url地址中輸入我們要訪問的url地址之后,瀏覽器要去請求這個url地址對應(yīng)的資源,本文具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • Vue中@change、@input和@blur的區(qū)別及@keyup介紹

    Vue中@change、@input和@blur的區(qū)別及@keyup介紹

    這篇文章主要給大家介紹了關(guān)于Vue中@change、@input和@blur的區(qū)別及@keyup介紹的相關(guān)資料,文中通過實例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2023-02-02
  • 解決vue 綁定對象內(nèi)點擊事件失效問題

    解決vue 綁定對象內(nèi)點擊事件失效問題

    今天小編就為大家分享一篇解決vue 綁定對象內(nèi)點擊事件失效問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09

最新評論