v-for循环input方法无法编辑_一个可视化json编辑组件的编写

一个可视化json编辑组件的编写

背景

一个功能,需要用户自定义json,并上传到对应的接口中。想要有可视化的操作。

解决路线

  1. 直接用一个文本框,让用户把编写好的json输入。
    被否决了。因为本身就是为了方便用户,不能直接让他们编写好,这样体验很不好。
  2. 一个类似键值对的形式,用几个输入框拼凑成key-value的形式

工具

vue + elementui

完成的效果

保留让用户直接输入的功能,又能可视化编辑4a9ba3ad7d091e22c56217ace63b2c83.png

be5c92ce319e9651ddfa1e5fd9be185f.png
可视化

实现过程

输入框直接输入的不谈,讲下可视化输入的解决过程。

  1. 分析json格式有哪些要素。
    基本的有:值  键值 由键值对构成的对象 数组。在这里,还要考虑到实际的业务场景,是需要一开始就是对象的形式。我们用一棵树来表达我们需要的元素吧。一开始考虑少了数组这个因素,导致实现的不合要求QAQ

cfed9c5d38bde6d44a020ff863cd4073.png
2. 解决vue组件循环依赖。由分析可以得到这是一个递归结构,因此最容易实现的方法就是用递归去实现。但是vue组件不能简单地通过import来互相引用,但是vue提供了循环依赖的支持。详情请看链接。

https://cn.vuejs.org/v2/guide/components-edge-cases.html#%E7%BB%84%E4%BB%B6%E4%B9%8B%E9%97%B4%E7%9A%84%E5%BE%AA%E7%8E%AF%E5%

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个使用element-ui的v-for循环el-form-item的组件代码示例: ```vue <template> <el-form> <el-form-item v-for="(field, index) in fields" :key="index" :label="field.label"> <el-input v-model="field.value" :placeholder="field.placeholder"></el-input> </el-form-item> </el-form> </template> <script> export default { props: { fields: { type: Array, required: true, default: () => [], }, }, }; </script> ``` 在上述代码中,我们使用了一个props属性来接收一个名为fields的数组,该数组中包含了每个表单项的label、placeholder和value属性。我们使用v-for循环该数组,并将其作为el-form-item的子组件,每个el-form-item包含了一个el-input组件,用于输入表单项的值。最后,我们将整个表单包裹在一个el-form组件中。 使用该组件时,我们只需要传递一个包含所有表单项的数组即可: ```vue <template> <my-form :fields="fields"></my-form> </template> <script> import MyForm from "@/components/MyForm.vue"; export default { components: { MyForm, }, data() { return { fields: [ { label: "姓名", placeholder: "请输入姓名", value: "", }, { label: "邮箱", placeholder: "请输入邮箱", value: "", }, { label: "电话", placeholder: "请输入电话", value: "", }, ], }; }, }; </script> ``` 在上述代码中,我们引入了刚才创建的MyForm组件,并将fields数组传递给该组件的props属性。fields数组中包含了三个表单项,分别是姓名、邮箱和电话。我们可以通过该组件来快速创建包含多个表单项的表单。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值