使用JS手寫一個類似?Laravel?驗證器的表單驗證器
介紹
Laravel 的表單驗證很方便,想在前端也用這樣的方式進行驗證。
期待這個表單驗證庫有這樣的功能。
let validator = new Validation(this.registerForm, { telephone: "required|telephone", captcha: "required|length:5", }, { telephone: { required: "手機號不能為空", telephone: "手機號格式不正確", }, captcha: "驗證碼不正確" }) try { validator.validate() } catch(e) { uni.showToast({ icon: 'error', title: e.message }) }
構(gòu)造函數(shù)的第三個參數(shù) messages 可以不要,默認(rèn)是英文提示。而且該參數(shù)支持不同粒度的錯誤信息,如果傳對象,則如果對應(yīng)的規(guī)則校驗不通過,就使用對應(yīng)的錯誤信息;如果傳字符串,則不論什么規(guī)則未通過,都使用該錯誤信息。
內(nèi)置一些規(guī)則,如果不夠用,還可以自己擴展。
根據(jù)以上的需求,就有了這個庫 @church1117/form-validation
。
安裝
npm install @church1117/form-validation
使用
import Validation from "@church1117/form-validation" let data = { name: "church", mobile: "18565919379", age: 19, gender: '2', password: "123456", captcha: "12345", idcard: '42052919910727452X', email: "xxx@qq.com", test: "ttt", birthday: '1993/11/17', } let rules = { name: "required|between:6,255", mobile: "required|telephone", age: "numeric|between:8,60", gender: "numeric|range:" + gender.join(','), password: "required|min:6|password", captcha: "required|length:5", idcard: "required|idcard", email: "email", // test: "required|testRule" birthday: "datetime" } let messages = { name: { required: "名字不能為空", between: "名稱長度必須在6~255之間", }, mobile: "不正確的手機格式", age: { numeric: "年齡不是一個有效的數(shù)值", between: "年齡必須在18-60歲之間" }, password: { required: "密碼不能為空", min: "密碼長度不能小于6位", regex: "密碼只能由數(shù)字、大小寫字母構(gòu)成", }, captcha: "驗證碼不正確", idcard: { required: "身份證不能為空", idcard: "身份證格式不正確", }, test: { required: "測試字段不能為空", testRule: "該字段的值必須為test" } } let validation = new Validation(data, rules, messages);
- messages 可以定義不同粒度的錯誤信息,如果是字符串,那么該字段的所有驗證規(guī)則都使用該錯誤信息。如果是對象,就只使用對應(yīng)規(guī)則的錯誤信息。
內(nèi)置規(guī)則
- required
- telephone
- min
- max
- between
- idcard
- range
- password
- numeric
- length
- datetime
自定義規(guī)則
匿名函數(shù)參數(shù)(value, field, ...params)
- value
- field
- ...params
Validation.register('testRule', function(value, field) { if (typeof value != 'undefined' && value != 'test') { throw new Error(`${field} must equal test`) } });
測試
npm test
以上就是使用JS手寫一個類似 Laravel 驗證器的表單驗證器的詳細(xì)內(nèi)容,更多關(guān)于JS Laravel表單驗證器的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
利用了jquery的ajax實現(xiàn)二級聯(lián)互動菜單
二級聯(lián)互動菜單,利用了jquery的ajax實現(xiàn),具體實現(xiàn)如下,喜歡的朋友可以參考下2013-12-12JavaScript實現(xiàn)簡單獲取本地圖片主色調(diào)
想象一個場景,就是如何根據(jù)一張圖片大概提取出它的主色調(diào)呢?獲取主色調(diào)后,可能會用來設(shè)置某些背景顏色,這里,利用?JS?簡單獲取本地圖片主色調(diào),希望對大家有所幫助2023-03-03在JavaScript里嵌入大量字符串常量的實現(xiàn)方法
在JavaScript文件里嵌入大量字符串常量是經(jīng)常遇到的事。有時為了省事,就把一些界面的HTML和CSS直接寫在JS文件里2013-07-07nuxt+axios實現(xiàn)打包后動態(tài)修改請求地址的方法
這篇文章主要介紹了nuxt+axios實現(xiàn)打包后動態(tài)修改請求地址的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04