vue使用vue-json-viewer展示JSON數(shù)據(jù)的詳細(xì)步驟
1.下載
npm下載:
// Vue2 npm install vue-json-viewer@2 --save // Vue3 npm install vue-json-viewer@3 --save
yarn下載:
// Vue2 yarn add vue-json-viewer@2 // Vue3 yarn add vue-json-viewer@3
2.引入并全局注冊
在main.js(入口文件里面)
import JsonViewer from 'vue-json-viewer' Vue.use(JsonViewer)
3.組件內(nèi)使用
jsonData就是你想要渲染的數(shù)據(jù)
<json-viewer :value="jsonData"></json-viewer>
假數(shù)據(jù)供測試效果:
data(){
return {
jsonData:{
name:"小明",
age:18,
items:{
like:"pingpang",
skip:0
}
}
}
}效果圖:

4.一點(diǎn)使用技巧、心得
在使用類似插件的時(shí)候,先寫假數(shù)據(jù),如果能正常渲染,那就將后端的數(shù)據(jù)處理成假數(shù)據(jù)一樣的格式。
另外,前端處理JSON數(shù)據(jù)一般使用JSON.parse()、eval()或者JSON.stringify()方法,要注意的是他們對格式的要求極其嚴(yán)格,如果你的數(shù)據(jù)格式不對,就會報(bào)錯(cuò)。相對來說我個(gè)人比較保險(xiǎn)的做法是:先JSON.parse(JSON.stringify())然后再JSON.parse()。
ps:JSON.stringify()序列化為JSON字符串;
JSON.parse()j解析為javascript對象
補(bǔ)充:設(shè)置編輯器的樣式使其風(fēng)格適用于項(xiàng)目
5.修改編輯的樣式,使其符合項(xiàng)目需求
第一步,在組件加一個(gè)屬性
theme="my-awesome-json-theme"
<json-viewer
v-for="(ite, idx) in finallyJsonList"
:key="idx"
style="width: 100%; min-width: 3.125rem"
:value="ite"
:expand-depth="5"
copyable
boxed
theme="my-awesome-json-theme"
sort
></json-viewer>第二步,在這個(gè)類名里面寫樣式了
需要注意的是,這個(gè)編輯器完全可以使用瀏覽器F12查看元素的類名去改,和我們平時(shí)開發(fā)沒啥區(qū)別,還是挺方便的。
.my-awesome-json-theme {
overflow-x: hidden;
background: #0c2b52;
white-space: nowrap;
color: #01fef4;
font-size: 14px;
font-family: Consolas, Menlo, Courier, monospace;
.jv-ellipsis {
color: rgb(237, 13, 13);
background-color: rgb(241, 11, 11);
display: inline-block;
line-height: 0.9;
font-size: 0.9em;
padding: 0px 4px 2px 4px;
border-radius: 3px;
vertical-align: 2px;
cursor: pointer;
user-select: none;
}
.jv-button {
color: #49b3ff;
}
::v-deep .jv-key {
color: #01fef4 !important;
}
::v-deep .jv-push {
color: #fff;
}
.jv-item {
&.jv-array {
color: #111111;
}
&.jv-boolean {
color: #fc1e70;
}
&.jv-function {
color: #067bca;
}
&.jv-number {
color: #fc1e70;
}
&.jv-number-float {
color: #fc1e70;
}
&.jv-number-integer {
color: #fc1e70;
}
&.jv-object {
color: #111111;
}
&.jv-undefined {
color: #e08331;
}
&.jv-string {
color: #42b983;
word-break: break-word;
white-space: normal;
}
}
.jv-code {
::v-deep .jv-toggle {
color: #067bca !important;
&:before {
padding: 0px 2px;
border-radius: 2px;
}
&:hover {
&:before {
background: rgb(242, 5, 5);
}
}
}
}
}總結(jié)
到此這篇關(guān)于vue使用vue-json-viewer展示JSON數(shù)據(jù)的文章就介紹到這了,更多相關(guān)vue-json-viewer展示JSON數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue實(shí)現(xiàn)具備掃描和查看數(shù)據(jù)的二維碼
在我們生活中,二維碼的應(yīng)用越來越廣泛,特別是在移動互聯(lián)網(wǎng)的時(shí)代,二維碼成為了快速傳達(dá)信息的一種利器,本文我們就來看看如何在Vue框架下,實(shí)現(xiàn)一個(gè)具備掃描和查看數(shù)據(jù)的二維碼吧2023-05-05
vue2使用ts?vue-class-component的過程
vue-property-decorator?是一個(gè)?Vue.js?的裝飾器庫,它提供了一些裝飾器來讓你在?Vue?組件中定義屬性、計(jì)算屬性、方法、事件等,本文給大家介紹vue2使用ts?vue-class-component的相關(guān)知識,感興趣的朋友一起看看吧2023-11-11
使用vue-router切換頁面時(shí)實(shí)現(xiàn)設(shè)置過渡動畫
今天小編就為大家分享一篇使用vue-router切換頁面時(shí)實(shí)現(xiàn)設(shè)置過渡動畫。具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10
vue2.0實(shí)現(xiàn)選項(xiàng)卡導(dǎo)航效果
這篇文章主要為大家詳細(xì)介紹了vue2.0實(shí)現(xiàn)選項(xiàng)卡導(dǎo)航效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
Vue中引入使用patch-package為依賴打補(bǔ)丁問題
這篇文章主要介紹了Vue中引入使用patch-package為依賴打補(bǔ)丁問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
vue中父子組件相互傳值的實(shí)現(xiàn)方法詳解
父子組件通信是Vue中常見的場景,這篇文章主要為大家詳細(xì)介紹了vue中父子組件相互傳值的實(shí)現(xiàn)方法,文中的示例代碼講解詳細(xì),需要的小伙伴可以參考一下2023-12-12
vue結(jié)合vue-electron創(chuàng)建應(yīng)用程序小結(jié)
這篇文章主要介紹了vue結(jié)合vue-electron創(chuàng)建應(yīng)用程序,本文給大家介紹了安裝electron有兩種方式,兩種方式創(chuàng)建的項(xiàng)目結(jié)構(gòu)大不相同,需要的朋友可以參考下2024-03-03

