本文介绍: vue3 使用 jsoneditor。复制代码放到文件中就能用了。
vue3 使用 jsoneditor
在main.js中引入 样式文件
import 'jsoneditor/dist/jsoneditor.css'
复制代码放到文件中就能用了
jsoneditor.vue
<template>
<div ref="jsonDom" style="width: 100%; height: 460px"></div>
</template>
<script setup lang="ts">
import { ref, onMounted, watchEffect } from 'vue'
import JsonEditor from 'jsoneditor'
interface validateResult {
path: Array<string | number>
message: string
}
const props = defineProps<{
option: any
validate?: (val: any) => validateResult
}>()
const emit = defineEmits(['update:modelValue', 'change', 'customValidation'])
const jsonDom = ref(null)
const validate = (res: any, editor: any) => {
try {
emit('change', {
success: res.length === 0 && typeof editor.get() !== 'number',
json: editor.getText()
})
} catch (error) {
console.log(error)
}
}
onMounted(() => {
const options = {
history: false,
sortObjectKeys: false,
mode: 'code',
modes: ['code', 'text'],
onChange() {
editor.validate().then((res: any) => validate(res, editor))
},
onBlur() {
try {
editor.set(eval(`(${editor.getText()})`))
editor.validate().then((res: any) => validate(res, editor))
} catch (error) {
console.log(error)
}
},
onValidate: props.validate,
onValidationError: function (errors: any) {
errors.forEach((error: any) => {
switch (error.type) {
case 'validation': // schema validation error
break
case 'customValidation': // custom validation error
emit('customValidation')
break
case 'error': // json parse error
emit('change', {
success: false,
json: editor.getText()
})
break
}
})
}
}
const editor = new JsonEditor(jsonDom.value, options)
watchEffect(() => {
editor.set(props.option)
editor.validate().then((res: any) => validate(res, editor))
})
})
</script>
原文地址:https://blog.csdn.net/Mrceel/article/details/135531708
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_55726.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。