办学质量监测教学评价系统
shenrongliang
2025-06-13 11d86cc6c26bb4f709e407acadf4805c2024e79f
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
<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>