国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Vue中使用JsonView來(lái)展示Json樹(shù)的實(shí)例代碼

瀏覽:2日期:2022-10-27 17:17:08

前兩天干活兒有個(gè)需求,在前端需要展示可折疊的Json樹(shù),供開(kāi)發(fā)人員查看,這里采用JsonView組件來(lái)實(shí)現(xiàn),它是一款用于展示Json的Vue組件,支持大體積的Json文件快速解析渲染,下面記錄一下實(shí)現(xiàn)過(guò)程。

1.首先先下載好JsonView的組件:JsonView.vue,組件代碼如下:

<template> <div class='bgView'> <div : :style='’font-size:’ + fontSize+’px’'> <span @click='toggleClose' : v-if='length'> </span> <div class='content-wrap'> <p class='first-line'> <span v-if='jsonKey' class='json-key'>'{{jsonKey}}': </span> <span v-if='length'> {{prefix}} {{innerclosed ? (’...’ + subfix) : ’’}} <span class='json-note'> {{innerclosed ? (’ // count: ’ + length) : ’’}} </span> </span> <span v-if='!length'>{{isArray ? ’[]’ : ’{}’}}</span> </p> <div v-if='!innerclosed && length' class='json-body'> <template v-for='(item, index) in items'> <json-view :closed='closed' v-if='item.isJSON' :key='index' :json='item.value' :jsonKey='item.key' :isLast='index === items.length - 1'></json-view> <p v-else :key='index'> <span class='json-key'>{{(isArray ? ’’ : ’'’ + item.key + ’'’)}} </span> : <span class='json-value'>{{item.value + (index === items.length - 1 ? ’’ : ’,’)}} </span> </p> </template> <span v-show='!innerclosed' class='body-line'></span> </div> <p v-if='!innerclosed && length' class='last-line'> <span>{{subfix}}</span> </p> </div> </div> </div></template><script> export default { name: ’jsonView’, props: { json: [Object, Array], jsonKey: { type: String, default: ’’ }, closed: { type: Boolean, default: false }, isLast: { type: Boolean, default: true }, fontSize: { type: Number, default: 13 } }, created() { this.innerclosed = this.closed this.$watch(’closed’, () => { this.innerclosed = this.closed }) }, data() { return { innerclosed: true } }, methods: { isObjectOrArray(source) { const type = Object.prototype.toString.call(source) const res = type === ’[object Array]’ || type === ’[object Object]’ return res }, toggleClose() { if (this.innerclosed) { this.innerclosed = false } else { this.innerclosed = true } } }, computed: { isArray() { return Object.prototype.toString.call(this.json) === ’[object Array]’ }, length() { return this.isArray ? this.json.length : Object.keys(this.json).length }, subfix() { return (this.isArray ? ’]’ : ’}’) + (this.isLast ? ’’ : ’,’) }, prefix() { return this.isArray ? ’[’ : ’{’ }, items() { if (this.isArray) { return this.json.map(item => { const isJSON = this.isObjectOrArray(item) return { value: isJSON ? item : JSON.stringify(item), isJSON, key: ’’ } }) } const json = this.json return Object.keys(json).map(key => { const item = json[key] const isJSON = this.isObjectOrArray(item) return { value: isJSON ? item : JSON.stringify(item), isJSON, key } }) } } }</script><style> .bgView { background-color: #fafafa; } .json-view { position: relative; display: block; width: 100%; height: 100%; white-space: nowrap; padding-left: 20px; box-sizing: border-box; } .json-note { color: #909399; } .json-key { color: rgb(147, 98, 15); } .json-value { color: rgb(24, 186, 24); } .json-item { margin: 0; padding-left: 20px; } .first-line { padding: 0; margin: 0; } .json-body { position: relative; padding: 0; margin: 0; } .json-body .body-line { position: absolute; height: 100%; width: 0; border-left: dashed 1px #bbb; top: 0; left: 2px; } .last-line { padding: 0; margin: 0; } .angle { position: absolute; display: block; cursor: pointer; float: left; width: 20px; text-align: center; left: 0; } .angle::after { content: ''; display: inline-block; width: 0; height: 0; vertical-align: middle; border-top: solid 4px #333; border-left: solid 6px transparent; border-right: solid 6px transparent; } .angle.closed::after { border-left: solid 4px #333; border-top: solid 6px transparent; border-bottom: solid 6px transparent; }</style>

2.在需要使用的vue頁(yè)面中引用JsonView組件

import JsonView from ’@/components/JsonView’

3.定義Json數(shù)據(jù)變量

jsonData:{},

4.頁(yè)面展示代碼

<JsonView :json='jsonData'></JsonView>

5.實(shí)現(xiàn)效果如下:

Vue中使用JsonView來(lái)展示Json樹(shù)的實(shí)例代碼

JsonViewAttributes

Vue中使用JsonView來(lái)展示Json樹(shù)的實(shí)例代碼

到此這篇關(guān)于Vue之使用JsonView來(lái)展示Json樹(shù)的文章就介紹到這了,更多相關(guān)Vue使用JsonView展示Json樹(shù)內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 美女流白浆网站 | 精品国产日韩久久亚洲 | 成人免费在线视频 | 亚洲精品视频在线 | 99久久伊人一区二区yy5o99 | 亚洲国产天堂久久综合网站 | 色播亚洲精品网站 亚洲第一 | 日本一极毛片兔费看 | 精品久久精品久久 | 国产成人精品久久一区二区小说 | 尤物蜜芽福利国产污在线观看 | 国产亚洲高清不卡在线观看 | 在线观看精品视频 | 欧美日韩高清 | 亚洲精品天堂自在久久77 | 99久久精品国产一区二区 | 91高清国产经典在线观看 | 亚洲专区在线视频 | 欧美一级毛片欧美一级成人毛片 | 亚洲天堂在线视频观看 | 欧美一级一极性活片免费观看 | 高清午夜线观看免费 | 女人张开腿给男人捅 | 欧美一区视频 | 亚洲黄色官网 | 欧美日本一区亚洲欧美一区 | 日本一区二区免费在线观看 | 草草视频在线播放 | 欧美三级网站在线观看 | 在线观看片成人免费视频 | 午夜成年人网站 | 亚洲成人在线网 | 日本在线观看不卡免费视频 | 亚洲欧美在线视频免费 | 中文字幕日韩一区二区 | 在线观看一级毛片 | 亚洲精品色综合色在线观看 | 欧美在线一级片 | 日本成a人伦片 | 日韩免费一级a毛片在线播放一级 | 草草影院ccyy国产日本欧美 |