vue項(xiàng)目頁面嵌入代碼塊vue-prism-editor的實(shí)現(xiàn)
需求:
1. 可輸入代碼,并且代碼語法高亮
2. 支持編輯和不可編輯模式
3. 提交到后端到代碼內(nèi)容為字符串格式
實(shí)現(xiàn)
在gitbug上找到vue-prism-editor,可以滿足以上需求。
使用
1.安裝vue-prism-editor
npm install vue-prism-editor
由于vue-prism-editor需要依賴 prismjs,所以還需要安裝prismjs
npm install prismjs
2.在需要使用vue-prism-editor的組件中引入
import { PrismEditor } from "vue-prism-editor"; import "vue-prism-editor/dist/prismeditor.min.css"; // import the styles somewhere // import highlighting library (you can use any library you want just return html string) import { highlight, languages } from "prismjs/components/prism-core"; import "prismjs/components/prism-clike"; import "prismjs/components/prism-javascript"; import "prismjs/themes/prism-tomorrow.css"; // import syntax highlighting styles
3.html代碼
<prism-editor class="my-editor height-300" v-model="code" :highlight="highlighter" :line-numbers="lineNumbers" ></prism-editor>
code----為需要高亮顯示的代碼內(nèi)容
highlighter----定義在methods中的一個(gè)方法,用于把code高亮顯示
lineNumbers----是否可編輯標(biāo)識(shí)
4.js代碼
export default { components: { PrismEditor }, data: () => ({ code: 'console.log("Hello World")', lineNumbers: true, // true為編輯模式, false只展示不可編輯 }), methods: { highlighter(code) { return highlight(code, languages.js); //returns html } } };
5.css代碼
<style lang="scss"> /* required class */ .my-editor { background: #2d2d2d; color: #ccc; font-family: Fira code, Fira Mono, Consolas, Menlo, Courier, monospace; font-size: 14px; line-height: 1.5; padding: 5px; } /* optional */ .prism-editor__textarea:focus { outline: none; } /* not required: */ .height-300 { height: 300px; } </style>
注意: css樣式必寫,不然編輯器沒有樣式,只是純白頁面展示
“height-300” 是給編輯器設(shè)置高度的,高度可自行設(shè)置,也可以不設(shè)置,這個(gè)樣式非必需
到這里,功能基本就實(shí)現(xiàn)了。
但是在過程中遇到一些問題,這里也一并總結(jié)。
問題
1.如果僅安裝vue-prism-editor
,沒有安裝prismjs,會(huì)報(bào)以下錯(cuò)誤,npm install prismjs
即可
2.如果報(bào)錯(cuò)中有提示升級(jí)或者安裝ajv或者vue2.6.X版本,根據(jù)提示安裝即可
npm install ajv@^6.9.1 npm install vue@^2.6.11
個(gè)人理解,如果ajv和vue版本過低,可能會(huì)導(dǎo)致vue-prism-editor
依賴的相關(guān)東西安裝不上,建議升級(jí)完ajv和vue之后,再重新安裝vue-prism-editor
和prismjs.
3.vue與vue-template-compiler版本不一致
卸載低版本vue-template-compiler
npm uninstall vue-template-compiler
然后安裝跟vue同樣版本的vue-template-compiler
npm install vue-template-compiler@2.6.11
到此這篇關(guān)于vue項(xiàng)目頁面嵌入代碼塊vue-prism-editor的文章就介紹到這了,更多相關(guān)vue項(xiàng)目頁面嵌入代碼塊內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
jdk1.8+vue elementui實(shí)現(xiàn)多級(jí)菜單功能
這篇文章主要介紹了jdk1.8+vue elementui實(shí)現(xiàn)多級(jí)菜單功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09解決Vue + Echarts 使用markLine標(biāo)線(precision精度問題)
這篇文章主要介紹了解決Vue + Echarts 使用markLine標(biāo)線(precision精度問題),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-07-07淺析Visual Studio Code斷點(diǎn)調(diào)試Vue
本篇文章給大家總結(jié)了Visual Studio Code斷點(diǎn)調(diào)試Vue的方法以及心得分享,需要的朋友參考學(xué)習(xí)下。2018-02-02vue3中的reactive函數(shù)聲明數(shù)組方式
這篇文章主要介紹了vue3中的reactive函數(shù)聲明數(shù)組方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05Vue.js使用axios動(dòng)態(tài)獲取response里的data數(shù)據(jù)操作
這篇文章主要介紹了Vue.js使用axios動(dòng)態(tài)獲取response里的data數(shù)據(jù)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-09-09vue?禁止重復(fù)點(diǎn)擊發(fā)送多次請(qǐng)求的實(shí)現(xiàn)
本文主要介紹了vue?禁止重復(fù)點(diǎn)擊發(fā)送多次請(qǐng)求的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03vue設(shè)置動(dòng)態(tài)請(qǐng)求地址的例子
今天小編就為大家分享一篇vue設(shè)置動(dòng)態(tài)請(qǐng)求地址的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-11-11Vue中金額、日期格式化插件@formatjs/intl的使用及說明
這篇文章主要介紹了Vue中金額、日期格式化插件@formatjs/intl的使用及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02Vue動(dòng)態(tài)組件?component?:is的使用代碼示范
vue?動(dòng)態(tài)組件用于實(shí)現(xiàn)在指定位置上,動(dòng)態(tài)加載不同的組件,這篇文章主要介紹了Vue動(dòng)態(tài)組件?component?:is的使用,需要的朋友可以參考下2023-09-09