仿MongoDB写一个数据编辑弹窗

前言

前一段时间做需求的时候,需要用户是可以编辑一些数据,相当于一个表单。我第一反应是MongoDB的数据可视平台。用户可以通过可视化来操作数据。我就仿着写了一版,大概就是下面这个样子。

文章后面有源码地址

正文

有几个问题需要解决

  1. 如何可以接受任意数据结构。
  2. 如何进行添加、修改、删除数据

接受任意的数据

常见的数据类型有几种

  • 字符串(String)
  • 数字(Number)
  • 布尔(Boolean)
  • 数组(Array)
  • 对象(Object)

想做到这几种数据类型随意组合编辑,使用递归就可以轻松解决,modal的内容都是通过Render函数渲染出来的,那么只要在恰当的时机再次调用就可以了

当一个值为数组或者对象时,就可以再次调用Render函数,这样就可以支持任意结构的数据

如何进行添加、修改、删除数据

要解决这个问题我们首先要知道,我们渲染数据的结构是什么样子的。这是最原始的结构,我们现在要改变name的值应该是value.name=xxxxx

如果是下面这个结构要改变class中的name,应该是value.class.name=xxxx

要是改变classdays中其中的一项,那应该是value.class.days[下标]=xxxx

从这里可以知道,我们只要知道了keys队列那么我们就可以任意改变数据中的某一个值。

在递归渲染的时候,我们将上一层的keys队列往下带就可以了。这样在改变值的时候只要加上他在自己层级的key就可以了。

在触发值修改时,只要根据keys队列我们就可以找到修改的值并进行修改。添加和删除都是一样的道理。

结尾

感兴趣的可以去试试 仓库地址

相关推荐
C语言魔术师13 分钟前
【小游戏篇】三子棋游戏
前端·算法·游戏
小周不摆烂19 分钟前
探索JavaScript前端开发:开启交互之门的神奇钥匙(二)
javascript
匹马夕阳1 小时前
Vue 3中导航守卫(Navigation Guard)结合Axios实现token认证机制
前端·javascript·vue.js
你熬夜了吗?1 小时前
日历热力图,月度数据可视化图表(日活跃图、格子图)vue组件
前端·vue.js·信息可视化
我想学LINUX2 小时前
【2024年华为OD机试】 (A卷,100分)- 微服务的集成测试(JavaScript&Java & Python&C/C++)
java·c语言·javascript·python·华为od·微服务·集成测试
screct_demo2 小时前
詳細講一下在RN(ReactNative)中,6個比較常用的組件以及詳細的用法
javascript·react native·react.js
桂月二二8 小时前
探索前端开发中的 Web Vitals —— 提升用户体验的关键技术
前端·ux
CodeClimb9 小时前
【华为OD-E卷 - 第k个排列 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
hunter2062069 小时前
ubuntu向一个pc主机通过web发送数据,pc端通过工具直接查看收到的数据
linux·前端·ubuntu
qzhqbb9 小时前
web服务器 网站部署的架构
服务器·前端·架构