您好,登錄后才能下訂單哦!
這篇文章主要介紹了如何實現(xiàn)amazeui頁面校驗功能,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
如下圖所示:
郵政“郵政編碼”字段,數(shù)據(jù)庫中是varchar2(10)。
但是amazeui的頁面校驗中,關(guān)于字符長度的校驗方式如下:
JS 表單驗證
JS 表單驗證基于 HTML5 的各項驗證屬性進行:
required
: 必填;
pattern
: 驗證正則表達式,插件內(nèi)置了 email
、url
、number
三種類型的正則表達式;
minlength
/maxlength
: 字符限制;
min
/max
: 最小、最大值限制,僅適用于數(shù)值類型的域;
minchecked
/maxchecked
: 至少、至多選擇數(shù),適用于 checkbox
、下拉多選框,checkbox
時將相關(guān)屬性的設(shè)置在同組的第一個元素上;
.js-pattern-xx
: 驗證規(guī)則 class,正則庫中存在的規(guī)則可以通過添加相應(yīng) class 實現(xiàn)規(guī)則添加。
注意:
HTML5 原生表單驗證中 pattern
只驗證值的合法性,也就是可以不填,如果填寫則必須符合規(guī)則。如果是必填項,仍要添加 required
屬性。該插件與 HTML5 的規(guī)則保持一致。
<!-- 下面三種寫法等效 --> <!-- 只內(nèi)置了 email url number 三種類型的正則,可自行擴展 --> <input type="email"/> <!-- js-pattern-xx 其中 xx 為 pattern 庫中的 key --> <input type="text" class="js-pattern-email"/> <input type="text" pattern="^(...email regex...)$"/>
即maxlength=10,amazeui的意思是可以輸入10個字(數(shù)字、字母、漢字等同對待,都視為一個字)
但是假如前段輸入了10個漢字”中中中中中中中中中中“,提交后肯定數(shù)據(jù)庫長度溢出,因為該字段數(shù)據(jù)庫的長度是varchar2(10)即10byte只能存3.3333個不到4個漢字(因為一個漢字如果GBK\GB2312編碼占2個字節(jié),但是unicode\utf-8編碼占3個字節(jié))。
所以僅maxlength=10不能正確的限制輸入,還要加上js-pattern-number這個限制(這個確保輸入的是整數(shù),這樣漢字就輸入不進去了)。
感謝你能夠認真閱讀完這篇文章,希望小編分享的“如何實現(xiàn)amazeui頁面校驗功能”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。