Vue3 使用json编辑器

安装

npm install json-editor-vue3

main中引入

main.js 中加入下面代码

javascript 复制代码
import "jsoneditor";

不然会有报错,如jsoneditor does not provide an export named 'default'。 图片信息来源-github

代码示例

javascript 复制代码
<template>
    <json-editor-vue class="editor" v-model="jsonobj" @blur="remarkValidate" currentMode="text" :modeList="modeList"
        :options="options" />
</template>

<script setup>
import JsonEditorVue from 'json-editor-vue3';
import { ref } from 'vue'

const jsonstr = ref("{ \"a\": 8, \"b\": \"2\", \"c\":8, \"d\":9, \"f\":99 }");
const jsonobj = ref(JSON.parse(jsonstr.value));

const options = ref({
    search: false,
    history: false,
})
const modeList= ref(["text", "view", "tree", "code", "form"]) // 可选模式

const remarkValidate = () => {
    let newjsonstr = JSON.stringify(jsonobj.value);
    console.log("remarkValidate", jsonobj.value, newjsonstr, jsonstr.value);
    if (jsonstr.value == newjsonstr) {
        console.log("no change")
    } else {
        jsonstr.value = newjsonstr
    }
}
</script>

补充说明

json-editor-vue3支持多种配置,如可选模式(多选)modeList、初始模式currentMode,历史记录开关history,搜索功能开关search等, 上面示例代码已做部分配置实验,具体可以参考github的配置介绍。

运行结果

相关推荐
BBB努力学习程序设计11 小时前
Bootstrap图片:让图片展示更优雅、更专业
前端·html
玉宇夕落11 小时前
深入理解 async/await:从原理到实战,彻底掌握 JavaScript 异步编程
前端
3秒一个大11 小时前
从代码示例看 ES8 中的 async/await:简化异步操作的利器
javascript
努力往上爬de蜗牛11 小时前
react native token失效 刷新机制
javascript·react native·react.js
Sailing11 小时前
🚀 Promise.then 与 async/await 到底差在哪?(这次彻底讲明白)
前端·javascript·面试
鹤鸣的日常11 小时前
Vue + element plus 二次封装表格
前端·javascript·vue.js·elementui·typescript
JarvanMo11 小时前
Flakeproof - 自动化 Flutter 的用户体验 (UX) 测试
前端
北慕阳11 小时前
速成Vue,自己看
前端·javascript·vue.js
shanyanwt11 小时前
1分钟解决iOS App Store上架图片尺寸问题
前端·ios
摇滚侠11 小时前
HTML5,CSS3,开启浮动布局后,主轴和侧轴的概念
前端·css3·html5