你好,
首先呢,正则是非常灵活的,所以校验也要分等级。
从严格角度来看,可以这么分析,从版本格式来考虑,其实不推荐限制长度,如下格式:
a.b(eg: 1.0, 1.100, 甚至 1.1000)
a.b.c (eg: 1.1.1, 1.12.1, 甚至 1.121.1)
如果再允许整数版本,还可以增加一个
a(其实也是可能>5位的嘛)
根据以上分析,可以使用“或”连接三种规则,合并生成一个正则表达式:
// 不限长度版本var rVersion = /^\d+$|^\d+\.\d+$|^\d+(\.\d+){1,2}$/
// 限制长度(每一位版本号应该是一位数)
// var rVersion = /^\d$|^\d\.\d$|^\d(\.\d){1,2}$/
现在来验证下:
var caseOne = '1'var caseTwo = '1.1'
var caseThree = '1.2.1'
var errorCase = '1..2'
console.log(rVersion.test(caseOne)) // true
console.log(rVersion.test(caseTwo)) // true
console.log(rVersion.test(caseThree)) // true
console.log(rVersion.test(errorCase)) // false
// 增加一个多位校验
console.log(rVersion.test('1.12.1')) // true
// 但是这种就不行了
console.log(rVersion.test('1.1.2.1')) // false
// 如果 rVersion = /^\d$|^\d\.\d$|^\d(\.\d){1,2}$/
// 那么'1.12.1'这个也通不过
console.log(/^\d$|^\d\.\d$|^\d(\.\d){1,2}$/.test('1.12.1')) // false
好了,大概就这么多,根据你的情况取舍吧。
希望能解决你的问题,望采纳。如有疑问可追问~~
js正则 匹配"或"的两个条件怎么写Aborted_connects
尝试已经失败的MySQL服务器的连接的次数。
Connections 试图连接MySQL服务器的次数。
Created_tmp_tables
当执行语句时,已经被创造了的隐含临时表的数量。
Delayed_insert_threads 正在使用的延迟插入处理器线程的数量。
Delayed_writes 用INSERT DELAYED写入的行数。
Delayed_errors 用INSERT
DELAYED写入的发生某些错误(可能重复键值)的行数。
Flush_commands 执行FLUSH命令的次数。
Handler_delete
请求从一张表中删除行的次数。
Handler_read_first 请求读入表中第一行的次数。
Handler_read_key