使用JS手寫一個(gè)類似?Laravel?驗(yàn)證器的表單驗(yàn)證器
介紹
Laravel 的表單驗(yàn)證很方便,想在前端也用這樣的方式進(jìn)行驗(yàn)證。
期待這個(gè)表單驗(yàn)證庫(kù)有這樣的功能。
let validator = new Validation(this.registerForm, {
telephone: "required|telephone",
captcha: "required|length:5",
}, {
telephone: {
required: "手機(jī)號(hào)不能為空",
telephone: "手機(jī)號(hào)格式不正確",
},
captcha: "驗(yàn)證碼不正確"
})
try {
validator.validate()
} catch(e) {
uni.showToast({
icon: 'error',
title: e.message
})
}構(gòu)造函數(shù)的第三個(gè)參數(shù) messages 可以不要,默認(rèn)是英文提示。而且該參數(shù)支持不同粒度的錯(cuò)誤信息,如果傳對(duì)象,則如果對(duì)應(yīng)的規(guī)則校驗(yàn)不通過(guò),就使用對(duì)應(yīng)的錯(cuò)誤信息;如果傳字符串,則不論什么規(guī)則未通過(guò),都使用該錯(cuò)誤信息。
內(nèi)置一些規(guī)則,如果不夠用,還可以自己擴(kuò)展。
根據(jù)以上的需求,就有了這個(gè)庫(kù) @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: "名稱長(zhǎng)度必須在6~255之間",
},
mobile: "不正確的手機(jī)格式",
age: {
numeric: "年齡不是一個(gè)有效的數(shù)值",
between: "年齡必須在18-60歲之間"
},
password: {
required: "密碼不能為空",
min: "密碼長(zhǎng)度不能小于6位",
regex: "密碼只能由數(shù)字、大小寫字母構(gòu)成",
},
captcha: "驗(yàn)證碼不正確",
idcard: {
required: "身份證不能為空",
idcard: "身份證格式不正確",
},
test: {
required: "測(cè)試字段不能為空",
testRule: "該字段的值必須為test"
}
}
let validation = new Validation(data, rules, messages);- messages 可以定義不同粒度的錯(cuò)誤信息,如果是字符串,那么該字段的所有驗(yàn)證規(guī)則都使用該錯(cuò)誤信息。如果是對(duì)象,就只使用對(duì)應(yīng)規(guī)則的錯(cuò)誤信息。
內(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`)
}
});測(cè)試
npm test
以上就是使用JS手寫一個(gè)類似 Laravel 驗(yàn)證器的表單驗(yàn)證器的詳細(xì)內(nèi)容,更多關(guān)于JS Laravel表單驗(yàn)證器的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
利用了jquery的ajax實(shí)現(xiàn)二級(jí)聯(lián)互動(dòng)菜單
二級(jí)聯(lián)互動(dòng)菜單,利用了jquery的ajax實(shí)現(xiàn),具體實(shí)現(xiàn)如下,喜歡的朋友可以參考下2013-12-12
JavaScript實(shí)現(xiàn)簡(jiǎn)單獲取本地圖片主色調(diào)
想象一個(gè)場(chǎng)景,就是如何根據(jù)一張圖片大概提取出它的主色調(diào)呢?獲取主色調(diào)后,可能會(huì)用來(lái)設(shè)置某些背景顏色,這里,利用?JS?簡(jiǎn)單獲取本地圖片主色調(diào),希望對(duì)大家有所幫助2023-03-03
js實(shí)現(xiàn)通過(guò)開始結(jié)束控制的計(jì)時(shí)器
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)通過(guò)開始結(jié)束控制的計(jì)時(shí)器,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-02-02
在JavaScript里嵌入大量字符串常量的實(shí)現(xiàn)方法
在JavaScript文件里嵌入大量字符串常量是經(jīng)常遇到的事。有時(shí)為了省事,就把一些界面的HTML和CSS直接寫在JS文件里2013-07-07
nuxt+axios實(shí)現(xiàn)打包后動(dòng)態(tài)修改請(qǐng)求地址的方法
這篇文章主要介紹了nuxt+axios實(shí)現(xiàn)打包后動(dòng)態(tài)修改請(qǐng)求地址的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
JS加載iFrame出現(xiàn)空白問(wèn)題的解決辦法
在使用IE6瀏覽器開發(fā)過(guò)程中出現(xiàn)各種奇葩問(wèn)題,非常棘手,費(fèi)勁腦汁終于問(wèn)題解決。小編把解決辦法分享到腳本之家平臺(tái),需要的朋友可以參考下2016-05-05

