在这里插入图片描述

vue-json-pretty

<template>
  <div class="json-view">
    <el-dialog
      title="数据展示"
      :visible="dialogVisible"
      width="50%"
      @close="handleCancel"
    >
      <div style="height: 600px; overflow: auto;">
        <vue-json-pretty
          :path="'res'"
          :data="app.componentList"
          :deep="3"
          :highlight-mouseover-node="true"
          :show-select-controller="true"
          :show-length="true"
        />
      </div>

      <span slot="footer" class="dialog-footer">
        <el-button size="mini" @click="handleCancel">取 消</el-button>
        <el-button
          v-clipboard:copy="JSON.stringify(app.componentList)"
          v-clipboard:success="onCopy"
          v-clipboard:error="onError"
          size="mini"
          type="success"
        >
          复 制
        </el-button>
      </span>
    </el-dialog>
  </div>
</template>
<script>
import VueJsonPretty from 'vue-json-pretty'
export default {
  name: 'JsonView',
  inject: ['app'],
  components: {
    VueJsonPretty
  },
  props: {
    dialogVisible: {
      type: Boolean,
      default: false
    }
  },
  methods: {
    handleCancel() {
      this.$emit('update:dialogVisible', false)
    },

    onCopy(e) {
      this.$message.success('JSON数据复制成功,请自行转换。')
    },

    onError() {
      this.$message({ type: 'warning', message: '复制失败' })
    }
  }
}
</script>


vue-json-viewer

Logo

前往低代码交流专区

更多推荐