精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Dooring可視化之從零實現動態表單設計器

開發 前端
之前筆者有寫過一篇如何設計動態表單配置平臺的文章,但是由于筆者電腦問題代碼丟失,所以后期重新實現了一套表單設計器,并優化了之前的設計方式,特地做一下總結和復盤。

[[431676]]

前言

之前筆者有寫過一篇如何設計動態表單配置平臺的文章,但是由于筆者電腦問題代碼丟失,所以后期重新實現了一套表單設計器,并優化了之前的設計方式,特地做一下總結和復盤。

你將收獲

  • 動態表單開發的一般思路
  • 可視化領域中的表單引擎
  • 從零實現一款動態表單設計器
  • 利用H5-Dooring開發一款表單設計平臺

正文

按照習慣,我們先看看表單設計器實現的效果展示:

上圖中我們將表單設計器集成到了H5-Dooring中,使其可以實現拖拽生成表單。

其次我們可以根據右邊的配置項,動態的添加某個表單組件或或者修改組件字段和數據源。在配置好表單之后我們還可以定制表單提交的api接口地址,以便實現用戶數據的可溯源性。

在開發之前,我們先分析一下動態表單設計的一般實現思路。

動態表單開發的一般思路

1. 靜態化配置列表

靜態化配置列表是最傳統的表單配置方式之一,基本思路就是利用母表來生成配置項,進而實現表單配置。類似于以下方式:

早期的網站配置就是類似于這種呢方案實現的,比如說我們要定制網站的主色,網站某些組件是否可見,是一種比較簡單的方式。但是缺點是每增加一個配置屬性,都要開發人員重新編寫一個字段配置代碼,這種方式在表單開發中非常不靈活,而且對代碼層有強依賴性,所以只適合做小型配置系統。比如個人網站,簡單的自定義表單。

2. 基于json schema的動態表單配置

基于json schema的動態表單配置有兩種實現方案, 一種就是支持在線修改json文件從而實現定制化,另一種就是完全無代碼操作,但是前提都需要提供一套通用的表單模版。類似于如下案例:

此種方案可以實現基本的表單自治。也是本文主要實現的方案。至于在線編寫json文件的方案。筆者之前也也過成熟的方案,具體可以參考:

基于jsoneditor二次封裝一個可實時預覽的json編輯器組件(react版)

3. 支持在線coding的混合式表單設計

支持在線編程的混合式表單設計方案是終極方案,也是目前流行的無代碼化平臺的思想之一。一方面它提供了基于json schema的動態表單配置, 對于一些強定制的,需要在線設計組件方案的模式,采用在線編程,實時打包成動態組件的方式,最后根據平臺的組件約定來實現組件庫的方式。如下圖所示:

 

 

在線代碼編輯可以使用react-codemirror2或者 react-monaco-editor插件來實現。至于在線打包,我們用nodejs完全可以實現,筆者在做Dooring項目的在線下載代碼時就用到了該方案,感興趣的可以了解一下。

可視化領域中的表單引擎

可視化領域一方面強調的是圖形(可視化)的設計,一方面是動態表單。比如說我們想傻瓜式的改變一張圖的數據,屬性,交互等,我們需要通過表單這一橋梁來實現:

 

 

所以我們需要設計一款適合公司產品的“表單引擎”,來動態根據圖形組件的類型渲染不同表單配置。這塊思想也是表單設計器要解決的問題之一。在下面的文章中我們會詳細介紹實現過程。

從零實現一款動態表單設計器

在實現表單設計器之前,我們先來整理一下思路和需求。在筆者的最初草圖中,它長這樣:

 

 

從草圖中我們可以提取到如下任務信息:

  • 定義一套表單組件庫
  • 確定表單全局屬性配置
  • 實現表單操作curd(增刪查改)

我們這里總結了幾個常用的表單組件如下:

  • 單選框
  • 復選框
  • 單行文本
  • 多行文本
  • 下拉框
  • 文件上傳
  • 日期框
  • 數值輸入框

以上這些基本滿足我們的日常開發需求,其次我們還可以開發數據源表單組件,列表組件,比如dooring實現的那樣:

 

 

類似的還有顏色面板這些,我們可以更具業務需求自行定制。

在完成表單組件庫之后,我們就需要根據配置項動態渲染了。也有兩種實現思路,一種就是類似于多條件判斷,如下:

  1.   item.type === 'Number' && 
  2.   <Form.Item label={item.namename={item.key}> 
  3.     <InputNumber min={1} max={item.range && item.range[1]} step={item.step} /> 
  4.   </Form.Item> 
  5.   item.type === 'Text' && 
  6.   <Form.Item label={item.namename={item.key}> 
  7.     <Input /> 
  8.   </Form.Item> 
  9.   item.type === 'TextArea' && 
  10.   <Form.Item label={item.namename={item.key}> 
  11.     <TextArea rows={4} /> 
  12.   </Form.Item> 

這樣做雖然可行,也有很多成熟系統采用該方案,但是一旦表單變多,比如一個頁面有幾十個甚至上百個表單項,那么我們將渲染m * n次(m為表單組件類型數,n為配置項個數)。另一種方式筆者看來是比較優雅的,可以將復雜度降低到O(n),也就是筆者常用的對象法。思路大至如下:將表單組件的類型作為對象的屬性,屬性值為對應的表單組件,這樣遍歷的時候只需要對應上對象的具體類型即可。 代碼如下:

 

  1. // 維護表單控件, 提高form渲染性能 
  2. const BaseForm = { 
  3.     "Text": (props) => { 
  4.         const { label, placeholder, onChange } = props 
  5.         return <Cell title={label}> 
  6.                     <Input type="text" placeholder={placeholder} onChange={onChange} />  
  7.                </Cell> 
  8.     }, 
  9.     "Number": (props) => { 
  10.         const { label, placeholder, onChange } = props 
  11.         return <Cell title={label}> 
  12.                     <Input type="number" placeholder={placeholder} onChange={onChange} />  
  13.                </Cell> 
  14.     } 
  15.  
  16. //  動態渲染表單 
  17.     formData.map((item, i) => { 
  18.         let FormItem = BaseForm[item.type] 
  19.         return <div className={styles.formItem} key={i}> 
  20.                   <FormItem {...item} /> 
  21.               </div> 
  22.     }) 

 

 

是不是很優雅呢?后期我們只需要在BaseForm里維護表單組件即可,而且還可以基于BaseForm對表單進行包裝,實現動態刪除,編輯等功能。如下:

 

 

 

 

包裝后的代碼如下:

 

 

  1. <div> 
  2.   <div className={styles.disClick}><FormItem {...item} /></div> 
  3.   <div className={styles.operationWrap}> 
  4.       <span onClick={handleEditItem}><EditOutlined /></span> 
  5.       <span onClick={handleDelItem}><MinusCircleOutlined /></span> 
  6.   </div> 
  7. </div> 

 

接下來我們看看表單的全局屬性,通過實際分析我們可以知道表單有如下外觀:

  • 表單標題
  • 表單背景圖片
  • 表單背景顏色
  • 提交按鈕樣式

所以他們因該成為表單設計的通用屬性,如下圖所示:

 

 

 

 

配置出來之后的表單可能長這樣:

 

 

 

 

以上的表單通過H5-Dooring設計而來。當然我們可以利用它設計更加自定的表單頁面。

最后一個比較使用的需求就是api定制,一般公司可能需要將用戶的錄入數據收集到自己的平臺,那么這個時候我們提供一個api表單提交接口積極很有必要了,上面筆者也展示過,實現很簡單,就是配置里多一個api的文本框即可。

最后一步就是實現表單的curd操作,展示如下:

編輯表單項:

 

 

刪除表單項:

 

 

添加表單項:

 

 

 

具體實現也比較簡單,只需要基于BaseForm進行包裝,添加刪除/編輯/添加按鈕即可。具體可以參考我的開源項目H5-Dooring,地址:H5-Dooring傳送門

利用H5-Dooring開發一款表單設計平臺

在H5編輯器Dooring的實現中,我們可以做抽象,每一個頁面組件可以看成特定的表單組件,如下圖:

 

 

 

 

我們可以利用dooring的能力對表單平臺進行拖拽,樣式設計,數據錄入等等操作,感興趣的朋友可以基于Dooring設計思路改造成自己的表單設計平臺。在文末筆者會附上dooring的github地址供大家研究參考。

H5可視化編輯器Dooring功能迭代說明

目前筆者實現的H5可視化編輯器H5-Dooring功能新增如下:

  • 實時保存功能
  • 添加進度條組件
  • 添加websocket通信
  • 實現在線下載代碼功能
  • 添加Button組件
  • 添加動態表單設計器

本文轉載自微信公眾號「趣談前端」

 

責任編輯:姜華 來源: 趣談前端
相關推薦

2021-07-12 17:23:47

零設計可視化引擎

2023-01-07 08:09:41

零代碼Dooring組件

2021-06-16 08:30:36

Dooring可視化數據源設計剖析

2021-06-16 07:05:03

安全

2021-09-27 08:31:01

數據可視化柱狀圖折現圖

2022-02-28 08:34:42

開發可視化大屏

2021-03-09 08:32:50

開發視化大屏H5-Dooring

2023-09-26 08:01:16

2024-01-29 00:51:39

前端開發利器

2020-09-07 12:42:18

表單可視化開源

2009-08-24 14:12:46

IT運維管理表單設計工具摩卡軟件

2023-08-14 23:45:55

2024-04-17 08:50:59

開源FormikReact 表單庫

2021-06-22 14:47:19

electronDooring架構

2017-10-14 13:54:26

數據可視化數據信息可視化

2023-03-16 20:46:40

可視化平臺迭代

2012-04-17 09:20:38

表單設計移動應用

2018-03-27 22:40:59

深度學習

2020-03-11 14:39:26

數據可視化地圖可視化地理信息

2024-03-11 08:32:02

點贊
收藏

51CTO技術棧公眾號

久久精品ww人人做人人爽| 日韩激情在线视频| 国产又粗又硬又长| 亚洲老妇色熟女老太| 亚洲激情专区| 一区二区三区四区在线观看视频 | 国产欧美日韩精品专区| 欧美xxxx精品| 999国产精品一区| 色天天综合色天天久久| 日韩中文字幕亚洲精品欧美| 无码国产伦一区二区三区视频 | 国产ts人妖一区二区三区| 一区二区三区在线播放视频| 国产成人高清精品免费5388| 欧美日韩精品电影| 国产 日韩 亚洲 欧美| 中文日本在线观看| 91啪亚洲精品| 99re在线视频上| 亚洲一区二区三区高清视频| 一区二区国产精品| 粗暴蹂躏中文一区二区三区| 亚洲精品videossex少妇| 黄色片一级视频| 在线中文字幕-区二区三区四区| 久久久精品综合| av一本久道久久波多野结衣| 中文字幕欧美色图| 亚洲在线黄色| 久久久欧美一区二区| 亚洲熟女少妇一区二区| 久久99国产成人小视频| 日韩你懂的在线播放| 欧美午夜性生活| 欧美gv在线| 亚洲一区欧美一区| 三年中文高清在线观看第6集| 青青久草在线| wwww国产精品欧美| 国产一区二区精品在线| 亚洲精品成人电影| 无码人妻精品一区二区50| 成人自拍在线| 欧美一区二区三区婷婷月色| 天天综合网日韩| 最新日韩一区| 欧美一a一片一级一片| 成人黄色片视频| 一本大道色婷婷在线| 亚洲高清视频在线| 轻点好疼好大好爽视频| 肉肉视频在线观看| 亚洲一区二区三区在线| 国产一区二区三区播放| 在线观看小视频| 亚洲最大色网站| 人人妻人人澡人人爽欧美一区| 手机av在线播放| 亚洲综合网站在线观看| www.男人天堂网| av老司机在线观看| 亚洲一区二区视频在线| 久久99久久99精品| 国产精选在线| 日韩欧美黄色动漫| 久久无码高潮喷水| 日韩欧美一区二区三区免费观看| 日本韩国精品在线| 日本亚洲精品在线观看| 女人喷潮完整视频| 中文字幕人成乱码在线观看| 黑人精品xxx一区| 黄色a级片免费| 欧美性片在线观看| 欧美日韩国产高清一区二区| 欧洲在线免费视频| 福利电影一区| 亚洲欧洲日产国码av系列天堂| 公肉吊粗大爽色翁浪妇视频| 天天做天天爱天天综合网2021| 欧美二区在线播放| 国产乡下妇女做爰视频| 美女被久久久| 91精品在线观看视频| 国精产品乱码一区一区三区四区| 99在线视频精品| 日本高清不卡三区| 浪潮av一区| 午夜一区二区三区视频| 狠狠色狠狠色综合日日小说| 欧美国产视频一区| 在线男人天堂| 8x福利精品第一导航| 四虎成人免费视频| 国产一区二区三区日韩精品| 久久精品国产电影| 日韩精品无码一区二区| 青青草97国产精品免费观看 | 亚洲网站免费观看| 粉嫩绯色av一区二区在线观看 | 色综合中文字幕| 日本网站在线看| 杨幂一区二区三区免费看视频| 日韩视频精品在线| 久久精品视频7| 国产乱子伦视频一区二区三区 | 求av网址在线观看| 一区二区在线观看免费| 青青在线视频观看| 日韩区一区二| 中文字幕日韩精品在线| 国产成年人免费视频| 麻豆一区二区三| 久久精品午夜一区二区福利| 中文字幕在线三区| 在线观看网站黄不卡| 欧美激情一区二区三区p站| 色喇叭免费久久综合| 欧美洲成人男女午夜视频| 国产成人精品一区二三区四区五区| 久久久久久久免费视频了| 日韩久久久久久久久久久久| 日韩黄色三级| 亚洲人成网站999久久久综合| 精品无码黑人又粗又大又长| 美女在线视频一区| 欧美日韩在线精品| 日韩激情电影| 亚洲国产精品va| 欧美成欧美va| 国产精品资源在线看| 亚洲a∨一区二区三区| 亚洲精品国产精品国产| 欧美成人性福生活免费看| 91大神福利视频| 日韩电影在线一区二区三区| 欧美精彩一区二区三区| 国产污视频在线播放| 精品福利视频一区二区三区| 免费在线黄色片| 国产高清在线观看免费不卡| 国产日本欧美在线| 亚洲成人精品综合在线| 最新国产精品拍自在线播放| 五月天中文字幕| 亚洲国产精华液网站w| av无码精品一区二区三区| 91黄色免费视频| 成人51免费| xxxxx91麻豆| 亚洲性生活大片| 欧美激情中文字幕一区二区| 天天爱天天操天天干| 国产精品片aa在线观看| 国产成+人+综合+亚洲欧洲 | 依依成人在线视频| 国产免费成人在线视频| 超碰在线97免费| 大片网站久久| 成人免费在线网址| av在线网址观看| 日韩欧美一级片| 日韩三级视频在线播放| 91麻豆免费看| 黄色国产小视频| 99精品电影| 999在线免费观看视频| 男插女视频久久久| 欧美成人a交片免费看| 欧美精品在线一区二区| 欧美日韩在线视频免费| 99久久er热在这里只有精品15| 亚洲 高清 成人 动漫| 精品av一区二区| 国产区精品视频| caopen在线视频| 亚洲国产成人av在线| 国产性生活视频| 自拍偷拍国产精品| 午夜剧场免费看| 首页国产欧美日韩丝袜| 综合色婷婷一区二区亚洲欧美国产| 国产精品日本一区二区不卡视频| 欧美精品久久久久久久免费观看| 偷拍自拍在线| 欧美日韩国产另类一区| www.av视频在线观看| 久久精品视频在线免费观看| 亚洲免费成人在线视频| 日韩午夜黄色| 日韩一区国产在线观看| 久久久久毛片免费观看| 97av在线视频| 思思99re6国产在线播放| 亚洲成人精品视频| 伊人网站在线观看| 天天影视色香欲综合网老头| 国产aaaaaaaaa| 不卡区在线中文字幕| 欧美第一页浮力影院| 色婷婷av国产精品| 免费高清在线视频一区·| 成人免费看片视频在线观看| 免费日韩一区二区三区| 国产一区视频在线播放| 男女羞羞在线观看| 久久精品在线视频| 日本精品专区| 日韩精品中文字幕一区| 337p粉嫩色噜噜噜大肥臀| 一区二区高清免费观看影视大全| 亚洲区自拍偷拍| 国产成人精品免费| 一级黄色特级片| 国产精品久久777777毛茸茸| 国产日韩第一页| 国产欧美日韩精品高清二区综合区| 国产高清精品一区二区三区| 午夜不卡一区| 国产精品高潮呻吟久久av野狼 | 国产精品一区二区三区久久| 2020国产在线| 日韩国产精品91| 国产精品久久久久影院日本 | 亚洲国产精品久久不卡毛片| 国产性猛交xx乱| 久久蜜桃一区二区| 中文字幕日韩三级片| 丁香一区二区三区| 国内av一区二区| 免费成人在线网站| 欧美伦理片在线看| 香蕉视频成人在线观看| 成人免费在线网| 欧美天天视频| 99在线观看视频免费| 欧美日韩国产欧| 日本中文字幕一级片| 亚洲成av人电影| 自拍偷拍一区二区三区| 日韩欧美一区二区三区免费看| 日韩精品久久久| 国产一卡不卡| 日韩欧美精品久久| 成人在线免费小视频| 亚洲欧美日韩综合一区| 日韩在线观看电影完整版高清免费悬疑悬疑 | 中文字幕一区二区在线视频| 91激情在线视频| 国产又粗又猛又黄视频| 在线观看区一区二| 伊人网av在线| 777亚洲妇女| 国产成人精品一区二区无码呦| 亚洲一区二区伦理| 欧洲成人性视频| 欧美性xxx| 国产精品美女在线| 欧美视频免费看| 亚洲一区二区三区四区在线播放| 精品一区二区三区四区五区| 91超碰在线免费观看| 97久久综合区小说区图片区| 岛国一区二区三区高清视频| 久久这里只有精品一区二区| 欧美成熟毛茸茸复古| 成人3d精品动漫精品一二三| 欧美性视频在线播放| 午夜久久黄色| 国产中文字幕视频在线观看| 日日夜夜免费精品| 一区二区三区欧美精品| 国产·精品毛片| 无码h肉动漫在线观看| 亚洲国产高清不卡| 国产精品成人69xxx免费视频| 亚洲一区在线看| 日韩一区二区视频在线| 欧美午夜精品久久久久久孕妇 | 精品久久久久一区| 天天射,天天干| 日精品一区二区| 资源网第一页久久久| 午夜视频一区| 亚洲熟女乱色一区二区三区| 秋霞成人午夜伦在线观看| 国产精品久久久久野外| 91视频观看免费| 久草手机视频在线观看| 亚洲高清视频的网址| 影音先锋黄色网址| 欧美va亚洲va香蕉在线| 欧美精品a∨在线观看不卡| 色阁综合伊人av| 美女视频在线免费| 国产精品偷伦视频免费观看国产 | 欧美一区二区三区影视| 午夜一区在线观看| www.亚洲天堂| 中文字幕不卡三区视频| 91社区国产高清| 你懂的一区二区三区| 国产一区二区片| 欧美aaa在线| 风间由美一二三区av片| 亚洲免费视频成人| 日韩在线视频不卡| 精品国免费一区二区三区| 国产一级免费片| 久久精品道一区二区三区| 天堂av手机在线| 久久久精品日韩欧美| 久久久精品国产sm调教| 欧美日韩成人综合| 青青草免费在线视频| 久久久久久69| 9999在线精品视频| 日日噜噜噜噜夜夜爽亚洲精品| 亚洲视频观看| 在线成人免费av| 国产精品乱人伦| 中文字幕精品视频在线观看| 亚洲高清久久网| 日韩成人伦理| 成人中文字幕+乱码+中文字幕| 免费欧美视频| 久色视频在线播放| 成人动漫视频在线| 免费一级片视频| 日韩视频在线观看一区二区| 在线免费看av| 国产精品h片在线播放| 精品国产导航| 97超碰在线人人| 成人免费黄色在线| 欧美黑人一级片| 日韩欧美国产一区二区三区| 国产在线一区二区视频| 国产日韩精品在线播放| 日韩av密桃| 欧美男女交配视频| 国产精品麻豆99久久久久久| 无码一区二区三区| 亚洲视频国产视频| 亚洲人体视频| 久久涩涩网站| 久久成人在线| 欧美18—19性高清hd4k| 色成人在线视频| 成人免费视频| 视频一区中文字幕| 污污网站免费观看| 国产精品久久毛片av大全日韩| 国产99久久久久久免费看| 亚洲网址你懂得| 日韩在线观看不卡| 亚洲 日韩 国产第一区| 久久精品国产精品亚洲红杏| 最新日韩免费视频| 制服丝袜一区二区三区| 91小视频xxxx网站在线| 国产精品二区在线观看| 亚洲高清激情| www.久久国产| 欧美天堂一区二区三区| 91福利在线视频| julia一区二区中文久久94| 国产精品九九| 午夜理伦三级做爰电影| 欧美在线不卡视频| 超碰在线最新| 国产一区二区三区色淫影院| 久久不射2019中文字幕| 999精品久久久| 精品国产乱码久久久久久久| 男人久久天堂| 亚洲巨乳在线观看| 国产毛片精品视频| 日本在线观看中文字幕| 国产一区二区三区在线观看视频| 日韩深夜福利网站| 久久久亚洲国产精品| 久久久亚洲精品一区二区三区| 欧美精品久久一区二区 | 国产专区欧美专区| 欧美日本一区二区视频在线观看 | 精品久久国产视频| 91精品国产高清久久久久久久久| 视频国产一区| 黄色片免费网址| 欧美日韩在线一区| 黄色在线观看网站| 蜜桃传媒视频麻豆一区| 久久成人麻豆午夜电影| 中文字幕在线字幕中文| 久久精品国产99国产精品澳门 | 一区二区三区久久网| 成人黄色在线看| 中文字幕在线观看视频一区|