Some checks failed
Deploy / deploy (push) Has been cancelled
Full-stack web application for Telegram management - Frontend: Vue 3 + Vben Admin - Backend: NestJS - Features: User management, group broadcast, statistics 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
52 lines
1.3 KiB
Vue
52 lines
1.3 KiB
Vue
<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>
|