vue中json格式化显示数据(vue-json-viewer)

 更新时间:2024年05月27日 09:03:04   作者:白桃与猫  
这篇文章主要给大家介绍了关于vue中json格式化显示数据(vue-json-viewer)的相关资料,Vue-json-viewer是一个Vue组件,用于在Vue应用中显示JSON数据的可视化工具,需要的朋友可以参考下

1. 安装

使用npm:

$ npm install vue-json-viewer@2 --save
// Vue2
$ npm install vue-json-viewer@3 --save
// Vue3

使用yarm:

$ yarn add vue-json-viewer@2 
// Vue2
$ yarn add vue-json-viewer@3 
// Vue3

使用pnpm也可以

2. 使用方法

main.ts中注册插件

import { createApp } from 'vue';
import JsonViewer from 'vue-json-viewer'
import App from './App.vue';

const app = createApp(App);
app.use(JsonViewer )

app.mount('#app');

在界面中使用

<template>
	 <json-viewer
          :value="data"
          :expand-depth="5"
          copyable
          boxed
          sort
          class="w-100%"></json-viewer>
</template>
<script setup lang="ts">
 const data =  {// 注意:绑定得数据一定是JSON,而不是JSON字符串
      total: 25,
      limit: 10,
      data: [
        {
          id: '5968fcad629fa84ab65a5247',
          firstname: 'Ada',
          lastname: 'Lovelace',
        },
      ],
    };
</script>

注意:在main.ts文件中可能会出现以下得ts类型报错:

无法找到模块“vue-json-viewer”的声明文件。

解决方法:

  • 先尝试安装 npm i --save-dev @types/vue-json-viewer
  • 如果上面方法不行,在全局的.d.ts 结尾的文件中添加上declare module 'vue-json-viewer'

3. json-viewer属性和方法

json-viewer属性:

json-viewer事件监听:

json-viewer插槽:

json-viewer快捷键:

4. 表格中原始数据和格式化数据切换

实现:给表格中每行数据单独添加一个变量,用于单独控制展示的方式。

   //获取到表格数据后,添加一个自定义变量,记录json显示的方式
    state.tableData.forEach((item) => {
      item.showJsonView = false;
    });
   <!--el-table-column 插槽中  -->
     <template #default="scope">
            <div v-if="col.key === 'accountConfig'">
              <el-link
                type="primary"
                :underline="false"
                @click="() => (scope.row.showJsonView = !scope.row.showJsonView)">
                {{ scope.row.showJsonView ? '原始数据' : '格式化数据' }}
              </el-link>
              <div v-if="scope.row.showJsonView">
                <json-viewer
                  :value="JSON.parse(scope.row[col.key])"
                  :expand-depth="1"
                  copyable></json-viewer>
              </div>
              <div v-else>
                <pre class="text-pre-wrap">{{ scope.row[col.key] }}</pre>
              </div>
            </div>
            <div v-else>
              {{ scope.row[col.key] }}
            </div>
          </template>

注:如果表格中有el-switch, 单独控制每行的操作,请求时显示的loading,也是同样的方法实现。

5. 自定义主题:

  • 添加 theme="my-awesome-json-theme" 到JsonViewer的组件属性上
  • 复制粘贴下面的模板并且根据自定义的theme名称做对应调整。
// values are default one from jv-light template
.my-awesome-json-theme {
  background: #fff;
  white-space: nowrap;
  color: #525252;
  font-size: 14px;
  font-family: Consolas, Menlo, Courier, monospace;

  .jv-ellipsis {
    color: #999;
    background-color: #eee;
    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 }
  .jv-key { color: #111111 }
  .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 {
    .jv-toggle {
      &:before {
        padding: 0px 2px;
        border-radius: 2px;
      }
      &:hover {
        &:before {
          background: #eee;
        }
      }
    }
  }
}

总结 

到此这篇关于vue中json格式化显示数据(vue-json-viewer)的文章就介绍到这了,更多相关vue中json格式化显示内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解Vue3中Teleport的使用

    详解Vue3中Teleport的使用

    门户(Portal)的概念是Vue3的新功能之一,也就是将模板 HTML 移至 DOM 的不同部分的方法。Portal 是 React 中的常见功能,Vue2 的 portal-vue &nbsp;库也提供了相似的功能。在 Vue3 中用 Teleport 对这个概念提供了原生支持。本文将介绍Teleport的相关用法
    2021-05-05
  • element table 数据量大页面卡顿的解决

    element table 数据量大页面卡顿的解决

    这篇文章主要介绍了element table 数据量大页面卡顿的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • 基于Vue3实现旋转木马动画效果

    基于Vue3实现旋转木马动画效果

    这篇文章主要为大家介绍了如何利用Vue3实现旋转木马的动画效果,文中的示例代码讲解详细,对我们学习Vue有一定的帮助,需要的可以参考一下
    2022-05-05
  • Vue3监听reactive对象中属性变化的方法

    Vue3监听reactive对象中属性变化的方法

    在 Vue 3 中,如果你想监听 reactive 对象中的某个属性发生的变化,你可以使用 watch 函数进行监听,watch 函数允许你观察 reactive 对象的某个属性或者整个对象,所以本文给大家介绍了Vue3监听reactive对象中属性变化的方法,需要的朋友可以参考下
    2024-08-08
  • vue项目element-ui级联选择器el-cascader回显的问题及解决

    vue项目element-ui级联选择器el-cascader回显的问题及解决

    这篇文章主要介绍了vue项目element-ui级联选择器el-cascader回显的问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • 使用Vue3实现一个简单的思维导图组件

    使用Vue3实现一个简单的思维导图组件

    思维导图是一种用于表示信息、想法和概念的图形化工具,本文将基于 Vue3和VueDraggable实现一个简单的思维导图组件,支持节点拖拽,编辑及节点之间的关系连接,希望对大家有所帮助
    2025-04-04
  • Vue.js图片滑动验证的实现示例

    Vue.js图片滑动验证的实现示例

    为了防止有人恶意使用脚本进行批量操作,会设置图片滑动验证,本文就介绍了Vue.js图片滑动验证的实现示例,感兴趣的可以了解一下
    2023-05-05
  • 在Vue项目中使用jsencrypt.js对数据进行加密传输的方法

    在Vue项目中使用jsencrypt.js对数据进行加密传输的方法

    这篇文章主要介绍了在Vue项目中使用jsencrypt.js对数据进行加密传输的方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-04-04
  • vue使用axios实现动态追加数据

    vue使用axios实现动态追加数据

    在vuejs中使用axios时,有时候需要追加数据,比如,移动端下拉触底加载,分页加载,滑动滚动条等,下面小编就来为大家介绍一下如何使用使用axios实现动态追加数据吧
    2023-10-10
  • vue2前端导出pdf文件实例demo

    vue2前端导出pdf文件实例demo

    在Vue应用中,将页面导出为PDF文件通常涉及到前端技术的组合,下面这篇文章主要给大家介绍了关于vue2前端导出pdf文件的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-09-09

最新评论