tsp-component
Version:
提供多端和react版本的UI组件
102 lines (96 loc) • 3.35 kB
text/typescript
const regexp = {
/** 空格 */
space: /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,
/** 数字 */
number: /^\d+$/,
/** 大写,小写,数字及特殊字符 */
char: /((?=[\x21-\x7e]+)[^A-Za-z0-9])/,
/** 姓名 */
name: /^[\u4e00-\u9fa5]{1,20}$/,
/** 手机号 */
// tel: /^((1[3,5,7,8][0-9])|(14[5,7])|(17[0,6,7,8]))\d{8}$/,
tel: /^(1\d{2}|852|853|832)\d{8}$|^886\d{9,10}$/,
/** 座机号 */
landline: /^((0\d{2,3})-)(\d{7,8})(-(\d{1,3}))?$/,
/** 金额 */
price: /^[0-9]+(.[0-9]{1,2})?$/,
/** 正数 */
integer: /^(-|\+)?\d+$/,
/** 身份证号 */
// tslint:disable-next-line:max-line-length
cardId: /^((1[1-5])|(2[1-3])|(3[1-7])|(4[1-6])|(5[0-4])|(6[1-5])|71|(8[12])|91)\d{4}((19\d{2}(0[13-9]|1[012])(0[1-9]|[12]\d|30))|(19\d{2}(0[13578]|1[02])31)|(19\d{2}02(0[1-9]|1\d|2[0-8]))|(19([13579][26]|[2468][048]|0[48])0229))\d{3}(\d|X|x)?$/,
/** emoji */
emoji: /\ud83c[\udf00-\udfff]|\ud83d[\udc00-\ude4f]|\ud83d[\ude80-\udeff]/g
};
const errorStyle = 'tsp-component-Input-error';
/**
* 验证是否必填
*/
function validateRequried(formControlElem: HTMLElement, callback?: (msg: string, elem: HTMLElement) => void): boolean {
const dataset = formControlElem.dataset;
if (dataset.required) {
if (dataset.value) {
return true;
} else {
if (callback) {
callback(dataset.requiredMsg, formControlElem);
}
return false;
}
} else {
return true;
}
}
/**
* 验证是否验证规则
*/
function validatePattern(formControlElem: HTMLElement, callback?: (msg: string, elem: HTMLElement) => void): boolean {
const dataset = formControlElem.dataset;
let regex;
let flag = true;
let msg = dataset.patternMsg;
let result;
if (!dataset.value) {
return true;
}
if (dataset.pattern) {
regex = new RegExp(eval(dataset.pattern));
switch (dataset.patternType) {
case 'space':
case 'char':
//case 'landline':
flag = regex.test(dataset.value) === false; break;
default: flag = regex.test(dataset.value).toString() === dataset.patternTrigger; break;
}
switch (dataset.patternType) {
case 'space': msg = msg || '不能输入空格'; break;
case 'number': msg = msg || '只能输入数字'; break;
case 'char': msg = msg || '不能输入非法字符'; break;
case 'name': msg = msg || '名字中不能包含特殊字符'; break;
case 'tel': msg = msg || '请输入正确的手机号'; break;
case 'landline': msg = msg || '请输入正确的座机号'; break;
case 'price': msg = msg || '请填写正确的金额(最多2位小数)'; break;
case 'integer': msg = msg || '请填写整数'; break;
case 'landline': msg = msg || '请输入正确的座机号'; break;
case 'cardId': msg = msg || '请输入正确的身份证号'; break;
default: break;
}
if (flag) {
result = true;
} else {
if (callback) {
callback(msg, formControlElem);
}
result = false;
}
} else {
result = true;
}
if (result) {
formControlElem.classList.remove(errorStyle);
} else {
formControlElem.classList.add(errorStyle);
}
return result;
}
export { regexp, validateRequried, validatePattern } ;