精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

亚洲一区二区黄| 亚洲精品国产品国语在线app| 2019国产精品自在线拍国产不卡| 性欧美13一14内谢| 亚洲我射av| 亚洲成人激情av| 日日骚一区二区网站| 国产丝袜视频在线观看| 国产日韩一区二区三区在线播放| 中文字幕亚洲国产| www.男人天堂| 亚洲精品毛片| 日韩欧美成人精品| 日本一区二区免费高清视频| 亚洲国产欧美另类| 免费日本视频一区| 91av国产在线| 久久久精品99| 99久久99热这里只有精品| 亚洲激情中文字幕| 精产国品一区二区三区| 亚洲爱爱视频| 精品日本美女福利在线观看| 99热都是精品| www.av在线| 91丨九色丨蝌蚪丨老版| 97视频中文字幕| 在线观看国产小视频| 国产欧美日本| 色综合色综合久久综合频道88| 呻吟揉丰满对白91乃国产区| 一道本一区二区三区| 亚洲第一福利在线观看| 在线观看视频你懂得| 2019年精品视频自拍| 一本一道波多野结衣一区二区| 999一区二区三区| 成人在线视频亚洲| 自拍偷自拍亚洲精品播放| 日本视频一区二区在线观看| 欧美理论在线观看| 不卡影院免费观看| 国产伦精品一区二区三区视频免费| 国产精品无码久久久久成人app| 日本aⅴ亚洲精品中文乱码| 欧美中文字幕在线观看| 中文字幕亚洲精品在线| 亚洲欧洲另类| 午夜精品国产精品大乳美女| 国产乡下妇女做爰视频| 日韩视频精品在线观看| 国产综合在线视频| 国产一区二区99| 亚洲一区二区免费看| 欧美一区二区三区免费视| 日韩av大片在线观看| 亚洲伊人观看| 国产成人久久久| 中文字幕人妻一区二区在线视频 | 精品色999| 亚洲欧美国产一区二区三区| 中文字幕一区二区人妻在线不卡| 一区二区美女| 中文字幕av日韩| 中文字幕无码日韩专区免费| 在线中文字幕第一区| 久久99青青精品免费观看| 一区二区在线观看免费视频| 欧美久久视频| 7m精品福利视频导航| 成人免费毛片视频| 麻豆成人久久精品二区三区小说| 成人av在线网址| 亚洲精品成人电影| 91在线观看视频| 日韩久久精品一区二区三区| 最新国产在线观看| 亚洲自拍另类综合| 成人羞羞国产免费网站| 国产乱子精品一区二区在线观看| 欧美一区二区三区视频免费| 无码国产精品一区二区免费式直播 | 欧美性猛交xxxx富婆| 久久这里只精品| 香蕉大人久久国产成人av| 亚洲精品第一国产综合精品| 91成人免费看| www.av导航| 91麻豆国产在线观看| 亚洲va韩国va欧美va精四季| 18+视频在线观看| 黄色一区二区在线观看| 日本人视频jizz页码69| 网站一区二区| 一区国产精品视频| 久久久精品一区二区涩爱| 亚洲影院一区| 96久久精品| 国产福利片在线| 亚洲中国最大av网站| 999在线免费视频| japanese色系久久精品| 在线日韩av观看| 日韩精品视频免费看| 青青草一区二区三区| 国产一区视频观看| 成人在线观看亚洲| 欧美在线观看你懂的| www.四虎精品| 99re6这里只有精品| 98精品国产高清在线xxxx天堂| 在线免费观看高清视频| 91麻豆6部合集magnet| 日本黄网站色大片免费观看| 快播电影网址老女人久久| 精品久久免费看| 三上悠亚在线观看视频| 喷白浆一区二区| 免费精品视频一区二区三区| 欧美videosex性欧美黑吊| 欧美日韩免费一区二区三区| 一本色道综合久久欧美日韩精品| 亚洲欧美亚洲| 91九色在线视频| 日本不卡视频| 欧美三级中文字幕| 波多野结衣av在线免费观看| 99国产精品| 国产欧美日本在线| 男男gaygays亚洲| 日韩欧美资源站| 波多野结衣视频播放| 欧美成人一品| 91久久伊人青青碰碰婷婷| 午夜激情视频在线观看| 欧美日韩一级黄| аⅴ天堂中文在线网| 久久综合五月| 日韩av一区二区三区美女毛片| 国产欧洲在线| 亚洲成成品网站| 国产午夜久久久| 不卡av免费在线观看| 欧美大片在线播放| 欧美一区二区三区久久| 全球成人中文在线| 久久精品蜜桃| 色8久久人人97超碰香蕉987| xxx在线播放| 日韩成人午夜电影| 无遮挡亚洲一区| 日本欧美在线| 欧美另类高清videos| 国模私拍视频在线| 亚洲国产aⅴ成人精品无吗| 国产精品久久久久久在线观看| 激情六月综合| 成人免费网站在线| 欧美人与禽性xxxxx杂性| 亚洲国产精品久久久久久| 亚洲精品1区2区3区| 久久综合色婷婷| 在线观看免费黄网站| 国产精品88久久久久久| 7777精品久久久大香线蕉小说| 日本高清成人vr专区| 亚洲成人动漫在线播放| 91视频久久久| 亚洲日本一区二区| 日本50路肥熟bbw| 美女日韩在线中文字幕| 亚洲一区二区三区精品在线观看| 精品国模一区二区三区欧美| 久久免费成人精品视频| 蜜桃视频在线免费| 日韩一级大片在线观看| 国产视频91在线| 国产欧美一区二区三区沐欲| 五月天婷婷影视| 在线亚洲激情| 一区二区三区四区在线视频| 福利片一区二区| 国产精品va在线播放| v片在线观看| 日韩精品亚洲元码| 国产精品嫩草影院桃色| 午夜伊人狠狠久久| 免费精品在线视频| av不卡在线观看| 免费av不卡在线| 国产精品乱看| 国产免费xxx| 久操精品在线| 91九色对白| 日本在线中文字幕一区二区三区| 九九久久国产精品| 99视频在线观看地址| 亚洲激情在线观看| 99精品久久久久久中文字幕| 色综合天天在线| 久久久综合久久| 中文字幕一区二区5566日韩| 成年人在线观看av| 国产成a人亚洲精品| 五月婷婷六月合| 国产视频一区欧美| www.亚洲成人网| 欧美成人自拍| 日韩欧美99| 日韩高清影视在线观看| 91嫩草国产在线观看| 国产成人亚洲一区二区三区| 欧美一区二区大胆人体摄影专业网站| 亚洲第一图区| 久久精品国产清自在天天线 | 91污片在线观看| 最好看的中文字幕| 老司机免费视频一区二区三区| 国产亚洲天堂网| 亚洲国产综合在线看不卡| 粉嫩av一区二区三区天美传媒| 999国产精品999久久久久久| 亚洲第一综合| 精品国产一区二区三区久久久蜜臀| 精品国产乱码久久久久久丨区2区| 人人爱人人干婷婷丁香亚洲| 成人免费xxxxx在线观看| 成人一级视频| 国产精品大片wwwwww| 欧美成人h版| 日韩免费观看在线观看| 伊人成综合网站| 97超碰国产精品女人人人爽| 精精国产xxxx视频在线中文版| 九九热这里只有精品免费看| 国产秀色在线www免费观看| 色哟哟入口国产精品| av色图一区| 日韩有码在线观看| 毛片免费不卡| 久久久精品久久| 伊人精品影院| 久久久亚洲国产天美传媒修理工| 欧美性爽视频| 国模视频一区二区三区| а√在线天堂官网| 91po在线观看91精品国产性色| 一区二区三区视频在线观看视频| 色吧影院999| 18在线观看的| 美女av一区二区| 黄页网站大全在线免费观看| 久久久免费电影| 国产99在线| 国产成人综合精品| 日韩城人网站| 97人人模人人爽人人喊38tv| 精品女人视频| 欧美日韩亚洲综合一区二区三区激情在线 | 黄色香蕉视频在线观看| 亚洲精品中文字幕在线观看| 久久久久成人精品无码| 欧美性猛交xxxx黑人猛交| 亚洲中文字幕无码爆乳av| 欧美人体做爰大胆视频| av加勒比在线| 国产手机视频精品| 天堂资源在线中文| 欧美成在线视频| 手机在线观看av| 国产精品视频久久久| 欧美经典一区| 欧美亚洲免费在线| 久久久精品久久久久久96| 日韩av在线播放不卡| 日韩精品亚洲专区| 亚洲欧美激情一区二区三区| 97久久人人超碰| 成人免费视频入口| 亚洲一区二区欧美日韩| 天堂免费在线视频| 欧美大片在线观看一区二区| 日韩a在线观看| 中文字幕国产精品久久| av理论在线观看| 人妖精品videosex性欧美| 先锋影音网一区二区| 精品国产一区二区三区麻豆免费观看完整版 | 国产一区二区三区91| 超碰97免费观看| 免费亚洲网站| 两女双腿交缠激烈磨豆腐| 久久久久久一级片| 欧美人妻精品一区二区免费看| 色欲综合视频天天天| 亚洲精品视频网| 日日噜噜噜夜夜爽亚洲精品| 日本蜜桃在线观看视频| 亚洲自拍欧美另类| 欧美日韩第一| aa在线观看视频| 国产精品白丝av| 超碰人人干人人| 欧美性猛交xxxx黑人猛交| 亚洲va欧美va| zzijzzij亚洲日本成熟少妇| 欧美大片免费高清观看| 国产麻豆一区二区三区在线观看| 91精品国产91久久久久久黑人| 99久久久无码国产精品6| 成人免费视频视频| 日韩一级片av| 欧美日韩aaaaa| 国产在线观看免费网站| 97国产精品视频| 97久久亚洲| 国产一二三四区在线观看| 免费美女久久99| 亚洲国产日韩一区无码精品久久久| 亚洲高清三级视频| av中文字幕免费在线观看| 日韩亚洲精品视频| 精品免费av一区二区三区| 欧美一区二区三区精美影视 | 亚洲欧美在线专区| www.久久久精品| 国产精品网站一区| 成人免费一区二区三区| 国产一区二区久久精品| 日本少妇一区| 色女人综合av| 秋霞午夜av一区二区三区| xxxx日本黄色| 欧美日韩在线综合| h视频网站在线观看| 国产精品久久久久久久9999| 欧美色图一区| 伊人国产在线视频| 国产精品人妖ts系列视频| 中文字字幕在线观看| 中文字幕日韩视频| 2019年精品视频自拍| 中文精品视频一区二区在线观看| 蜜臀91精品一区二区三区| 欧美色图17p| 制服丝袜日韩国产| dy888亚洲精品一区二区三区| 91精品视频在线看| 国产一区日韩一区| 亚洲欧美高清在线| 粉嫩老牛aⅴ一区二区三区| 欧美69xxxxx| 国产精品爽爽爽爽爽爽在线观看| 色爱综合av| 丰满少妇在线观看| 中文字幕一区av| 亚洲第一页视频| 91av成人在线| 日韩成人综合| 香蕉视频xxxx| 欧美日韩另类视频| lutube成人福利在线观看| 亚洲一区二区三区久久| 在线国产日韩| 性の欲びの女javhd| 538在线一区二区精品国产| 黄页网站在线| 日韩欧美精品在线不卡| 国产在线精品一区二区夜色| 国产亚洲欧美精品久久久www| 精品亚洲一区二区三区在线播放| 日韩毛片在线| 日韩精品在线视频免费观看| 久久夜色精品国产欧美乱极品| 亚洲视频一区在线播放| 欧美精品18videos性欧美| 久久av影视| 在线成人精品视频| 色综合久久中文综合久久97| 男人影院在线观看| 国产在线欧美日韩| 精品一区二区三区欧美| 国产在线观看成人| 中文字幕欧美国内| 成人在线超碰| 一区二区三区韩国| 亚洲v精品v日韩v欧美v专区| 成人在线二区| 精品久久久久久中文字幕动漫 | 国产噜噜噜噜噜久久久久久久久| 欧美影视一区| 免费观看a级片| 精品99一区二区三区| 黑人一区二区三区| 黄色国产一级视频| 亚洲视频 欧洲视频| 国产中文字幕在线播放| 超碰97在线资源| 久久精品国产免费| 无码人妻精品一区二区50|