使用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 可以不要,默認是英文提示。而且該參數(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 驗證器的表單驗證器的詳細內(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-12
JavaScript實現(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-07
nuxt+axios實現(xiàn)打包后動態(tài)修改請求地址的方法
這篇文章主要介紹了nuxt+axios實現(xiàn)打包后動態(tài)修改請求地址的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04

