index.vue 1.27 KB
<script lang="ts" setup>
import type { JsonViewerAction, JsonViewerValue } from '@vben/common-ui';

import { JsonViewer, Page } from '@vben/common-ui';

import { Card, message } from 'ant-design-vue';

import { json1, json2 } from './data';

function handleKeyClick(key: string) {
  message.info(`点击了Key ${key}`);
}

function handleValueClick(value: JsonViewerValue) {
  message.info(`点击了Value ${JSON.stringify(value)}`);
}

function handleCopied(_event: JsonViewerAction) {
  message.success('已复制JSON');
}
</script>
<template>
  <Page
    title="Json Viewer"
    description="一个渲染 JSON 结构数据的组件,支持复制、展开等,简单易用"
  >
    <Card title="默认配置">
      <JsonViewer :value="json1" />
    </Card>
    <Card title="可复制、默认展开3层、显示边框、事件处理" class="mt-4">
      <JsonViewer
        :value="json2"
        :expand-depth="3"
        copyable
        :sort="false"
        @key-click="handleKeyClick"
        @value-click="handleValueClick"
        @copied="handleCopied"
        boxed
      />
    </Card>
    <Card title="预览模式" class="mt-4">
      <JsonViewer
        :value="json2"
        copyable
        preview-mode
        :show-array-index="false"
      />
    </Card>
  </Page>
</template>