js 正则表达式

校验正整数且不能大于1000

const reg = /^[1-9]\d{0,2}$|^1000$/;
const input = '999';

if (reg.test(input)) {
  console.log('输入符合要求');
} else {
  console.log('输入不符合要求');
}

校验数字不能大于1000且小数点最多六位小数

const reg = /^(((([1-9]\d{0,2})|(0{1}))(\.\d{1,6}))?|1000(\.0{1,6})?)$/;
const str = 999.123456; // 这个字符串是合法的
if (reg.test(str)) {
  console.log(`${str} 是合法的`);
} else {
  console.log(`${str} 是非法的`);
}

  解释:

  • [1-9]\d{0,2}:匹配1到999的数字
  • 0{1}: 0开头的话只能输入一位,如:0.234567

  • (\.\d{1,6})?:可选的小数部分,最多六位小数
  • |:或者
  • 1000(\.0{1,6})?:匹配1000或1000.000000
  • $:匹配字符串的结尾

校验邮箱

const reg = /^[A-Za-z\d]+([-_.][A-Za-z\d]+)*@([A-Za-z\d]+[-.])+[A-Za-z\d]{2,5}$/;
const str = '123@qq.com'; // 这个字符串是合法的
if (reg.test(str)) {
  console.log(`${str} 是合法的`);
} else {
  console.log(`${str} 是非法的`);
}

校验文件命名

var reg = new RegExp('[\\\\/:*?\"<>|]');
const str = '123'; 
if (reg .test(str)) {
  console.log(`${str} 是合法的`);
} else {
  console.log(`${str} 是非法的`);
}

校验输入小于100的数,且小数点后最多为两位小数

let reg = /^(([1-9][0-9]?)|([0]\.\d{1,2}|[1-9][0-9]?\.\d{1,2})|0)$/
const str = 123; 
if (reg .test(str)) {
  console.log(`${str} 是合法的`);
} else {
  console.log(`${str} 是非法的`);
}

校验输入不大于100的数,且小数点后最多为两位小数

let reg =  /^(([1-9][0-9]?)|([0]\.\d{1,2}|[1-9][0-9]?\.\d{1,2})|0|100)$/
const str = 100; 
if (reg.test(str)) {
  console.log(`${str} 是合法的`);
} else {
  console.log(`${str} 是非法的`);
}

校验数字不能大于30

let reg =  /^(?:[1-2]?[0-9]|30)$/
const str = 28; 
if (reg .test(str)) {
  console.log(`${str} 是合法的`);
} else {
  console.log(`${str} 是非法的`);
}

校验大于0的数,小数点后最多为八位小数的数字

let reg =  /^(?!0+(\.0+)?$)\d+(\.\d{1,8})?$/
const str = 0.01; 
if (reg .test(str)) {
  console.log(`${str} 是合法的`);
} else {
  console.log(`${str} 是非法的`);
}

// 或者

let reg1 =  /^(([1-9]\d*)|(([0]\.\d{1,9}|[1-9]\d*\.\d{1,9})))$/
const str = 0.01; 
if (reg1 .test(str)) {
  console.log(`${str} 是合法的`);
} else {
  console.log(`${str} 是非法的`);
}

校验0-1的数,且最多两位小数

let reg =  /^([0]\.\d{1,2}|1|0)$/
const str = 0.01; 
if (reg .test(str)) {
  console.log(`${str} 是合法的`);
} else {
  console.log(`${str} 是非法的`);
}

校验输入数字,且小数点后最多为两位小数的数字
 

let reg =  /^\d+(\.\d{1,2})?$/
const str = 0.01; 
if (reg.test(str)) {
  console.log(`${str} 是合法的`);
} else {
  console.log(`${str} 是非法的`);
}

校验大于0的整数


let reg =  /^[1-9]\d*$/
const str = 0.01; 
if (reg .test(str)) {
  console.log(`${str} 是合法的`);
} else {
  console.log(`${str} 是非法的`);
}

校验输入整数,且数字用英文逗号分隔


let reg = /^[\d]+(,[\d]+)*$/
const str = 0.01; 
if (reg .test(str)) {
  console.log(`${str} 是合法的`);
} else {
  console.log(`${str} 是非法的`);
}

校验输入数字,且数字用英文逗号分隔不超过两位小数


let reg = /^(?:\d{1,2}(?:\.\d{1,2})?|(?!100(?:\.0{1,2})?)\d{1,2}(?:\.\d{1,2})?)(?:,(?:\d{1,2}(?:\.\d{1,2})?|(?!100(?:\.0{1,2})?)\d{1,2}(?:\.\d{1,2})?))*$$/
const str = 0.01; 
if (reg .test(str)) {
  console.log(`${str} 是合法的`);
} else {
  console.log(`${str} 是非法的`);
}

解释:

     用于验证一个逗号分隔的数字列表,每个数字可以是整数或小数,并且可以是介于0到100之间的值(包括0和100),但不包括100。这个正则表达式的结构可以分解如下:

  • ^: 匹配字符串的开始。
  • (?: ...): 非捕获型分组,用于将多个元素组合成一个整体。
  • \d{1,2}: 匹配1到2位数字。
  • \.\d{1,2}: 匹配小数点及其后面的1到2位数字。
  • (?! ...): 负向先行断言,用于限制接下来的内容不能匹配括号内的模式。
  • 100(?:\.0{1,2})?): 匹配100,但不匹配100.0或100.00。
  • *: 匹配0个或多个前面的元素。
  • $: 匹配字符串的结尾。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
JavaScript正则表达式和Java正则表达式在语法上有一些差异,但是它们的基本概念和用法是相似的。下面是将JavaScript正则表达式转换为Java正则表达式的一些常见规则: 1. 语法差异: - JavaScript正则表达式使用斜杠(/)作为定界符,而Java正则表达式使用双引号(")作为定界符。 - JavaScript正则表达式中的特殊字符需要进行转义,而Java正则表达式中的特殊字符不需要转义。 2. 字符类: - JavaScript正则表达式中的字符类使用方括号([])表示,而Java正则表达式中使用方括号([])或者Unicode转义(\p{...})表示。 - JavaScript正则表达式中的字符类可以使用连字符(-)表示范围,而Java正则表达式中需要使用Unicode转义(\uXXXX)表示范围。 3. 量词: - JavaScript正则表达式中的量词使用花括号({})表示,而Java正则表达式中使用花括号({})或者问号(?)表示。 - JavaScript正则表达式中的贪婪量词默认是贪婪模式,而Java正则表达式中的贪婪量词需要在后面添加问号(?)来表示非贪婪模式。 4. 边界匹配: - JavaScript正则表达式中的边界匹配使用插入符号(^)和美元符号($)表示,而Java正则表达式中使用\A和\Z表示。 5. 其他差异: - JavaScript正则表达式中的捕获组使用圆括号(())表示,而Java正则表达式中使用圆括号(())或者方括号([])表示。 - JavaScript正则表达式中的反向引用使用反斜杠加数字(\1、\2等)表示,而Java正则表达式中使用美元符号加数字($1、$2等)表示。 以上是一些常见的JavaScript正则表达式转换为Java正则表达式的规则。具体转换时,还需要根据具体的正则表达式进行适当的调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值