前言
本文將介紹我們的表單解決方案?@femessage/el-form-renderer,展示我們在?Vue?技術棧下,我們是如何處理以下問題的:
表單項動態顯示或隱藏
表單數據聯動
表單輸入/輸出數據格式化
非常規表單項的處理
復雜的表單驗證
方案 表單項動態顯示或隱藏(hidden)可以通過?hidden?控制某一表單項的顯示或隱藏。
表單數據聯動(on)
可以通過 on?來監聽 blur?, focus?等事件來實現表單聯動。
舉個例子,填寫 fullName?后,自動填充 lastName?
輸入/輸出格式化(inputFormat/outputFormat)
拿 日期范圍選擇器?為例,組件輸出的值是一條字符串,但后端接口格式是兩個字段 {startDate, endDate},則此時需要對數據進行格式化處理。
inputFormat轉換輸入的數據, 使其變成表單項需要的數據格式
outputFormat
轉換輸出的數據, 使其變成需要的(接口期望的)數據格式
@femessage/el-form-renderer?默認支持的?type?有限, 只能渲染常見的表單項。對于個性化的需求,?比如想渲染一個上傳組件,type?就不夠用了, 那怎么辦呢? 這時候 component? 選項就派上用場了。
component可以渲染自定義組件,而編寫自定義組件的關鍵是在組件內部實現 v-model:
有一個 props 為 value
對外觸發 input 事件
幫我輸入點東西
則可以用 component? 屬性讓?@femessage/el-form-renderer?渲染此自定義組件
目前團隊對常見的表單擴展組件都根據標準實現了 v-model, 因此都可以不寫 template, 由?@femessage/el-form-renderer?實現數據驅動渲染
上傳組件?https://github.com/FEMessage/upload-to-ali
富文本編輯器?https://github.com/FEMessage/v-editor
省市區選擇器?https://github.com/FEMessage/el-select-area
范圍輸入框?https://github.com/FEMessage/el-number-range
版本號輸入框?https://github.com/FEMessage/el-semver-input
復雜的表單驗證(rules)一個復雜的表單項配置, 往往需要定義一些規則(rules)來限制用戶輸入, 規則里面可能還會有自定義的驗證器(validator), 這樣的表單項多了之后, 就會導致頁面文件的配置項變得很長很長。
解決方案是在組件內部設置校驗規則, 從而達到封裝隱藏目的。 使用者不用關心表單的驗證規則,直接引入組件并使用就好。
下面展示一個結合自定義組件(基本輸入框)封裝的驗證規則,?其規則如下:
不允許空值
只能輸入3位數或以上
必須以123開頭
同樣地,使用 component 渲染此組件
結語
我們內部項目都在使用?@femessage/el-form-renderer,可以在 github?上找到更多信息。
歡迎大家使用,提高項目開發效率~
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/106052.html
摘要:在實際開發項目中,有時我們會用到自定義按鈕因為一個項目中,眾多的頁面,為了統一風格,我們會重復用到很多相同或相似的按鈕,這時候,自定義按鈕組件就派上了大用場,我們把定義好的按鈕組件導出,在全局引用,就可以在其他組件隨意使用啦,這樣可以大幅度 在實際開發項目中,有時我們會用到自定義按鈕;因為一個項目中,眾多的頁面,為了統一風格,我們會重復用到很多相同或相似的按鈕,這時候,自定義按鈕組件就...
摘要:代碼整潔之道整潔的代碼不僅僅是讓人看起來舒服,更重要的是遵循一些規范能夠讓你的代碼更容易維護,同時降低幾率。另外這不是強制的代碼規范,就像原文中說的,。里式替換原則父類和子類應該可以被交換使用而不會出錯。注釋好的代碼是自解釋的。 JavaScript代碼整潔之道 整潔的代碼不僅僅是讓人看起來舒服,更重要的是遵循一些規范能夠讓你的代碼更容易維護,同時降低bug幾率。 原文clean-c...
對比內容UCloudStackZStackVMwareQingCloud騰訊TStack華為云Stack優勢總結?基于公有云自主可控?公有云架構私有化部署?輕量化/輕運維/易用性好?政府行業可復制案例輕量化 IaaS 虛擬化平臺?輕量化、產品成熟度高?業內好評度高?功能豐富、交付部署快?中小企業案例多全套虛擬產品及云平臺產品?完整生態鏈、技術成熟?比較全面且健全的渠道?產品成熟度被市場認可,市場占...
摘要:能跨平臺地設置及使用環境變量讓這一切變得簡單,不同平臺使用唯一指令,無需擔心跨平臺問題安裝方式改寫使用了環境變量的常見如在腳本多是里這么配置運行,這樣便設置成功,無需擔心跨平臺問題關于跨平臺兼容,有幾點注意 cross-env能跨平臺地設置及使用環境變量, cross-env讓這一切變得簡單,不同平臺使用唯一指令,無需擔心跨平臺問題 1、npm安裝方式 npm i --save-de...
摘要:引入的模塊引入的使用將打包打包的拆分將一部分抽離出來物理地址拼接優化打包速度壓縮代碼,這里使用的是,同樣在的里面添加 const path = require(path); //引入node的path模塊const webpack = require(webpack); //引入的webpack,使用lodashconst HtmlWebpackPlugin = require(ht...
閱讀 3104·2021-10-13 09:40
閱讀 3959·2021-09-22 15:51
閱讀 1504·2021-09-22 15:48
閱讀 1073·2021-09-06 15:00
閱讀 1797·2019-08-30 15:43
閱讀 2367·2019-08-29 18:35
閱讀 1678·2019-08-29 16:18
閱讀 3622·2019-08-29 12:49