JS的正则表达式实例
js的replaceall 正则表达式
js的replaceall 正则表达式使用JavaScript的replaceAll正则表达式在JavaScript中,我们经常需要对字符串进行替换操作,例如将某个字符串中的特定字符或模式替换为其他字符或字符串。
在这种情况下,我们可以使用JavaScript的replaceAll()方法来实现。
该方法可以接受一个正则表达式作为参数,用于匹配要替换的字符或模式,并将其替换为指定的字符或字符串。
让我们来看一下replaceAll()方法的语法:str.replaceAll(regexp, newSubStr)其中,str是要进行替换操作的字符串,regexp是一个正则表达式,用于匹配要替换的字符或模式,newSubStr是用于替换的新字符或字符串。
接下来,让我们通过一些例子来说明如何使用replaceAll()方法。
例子1:将字符串中的所有空格替换为下划线```let str = "Hello World! This is a test.";let newStr = str.replaceAll(/\s/g, "_");console.log(newStr);// Output: "Hello_World!_This_is_a_test."```在这个例子中,我们使用正则表达式/\s/g来匹配字符串中的所有空格。
其中,\s表示空白字符,g表示全局匹配。
然后,我们将空格替换为下划线,并将结果赋值给newStr变量。
最后,我们打印出newStr的值,结果为"Hello_World!_This_is_a_test."。
例子2:将字符串中的所有数字替换为空字符```let str = "The number is 12345.";let newStr = str.replaceAll(/\d/g, "");console.log(newStr);// Output: "The number is ."```在这个例子中,我们使用正则表达式/\d/g来匹配字符串中的所有数字。
js正则判断是否为数字的方法
js正则判断是否为数字的方法【原创版4篇】篇1 目录1.介绍 JavaScript 正则表达式2.讲解如何使用正则表达式判断数字3.提供实例代码篇1正文一、JavaScript 正则表达式概述正则表达式(Regular Expression,简称 regex)是一种用于匹配字符串模式的字符集,通常用于文本搜索和数据提取等场景。
在 JavaScript 中,正则表达式广泛应用于验证输入、提取数据等功能。
二、如何使用正则表达式判断数字在 JavaScript 中,可以使用正则表达式来判断一个字符串是否为数字。
具体的方法是使用正则表达式的测试方法(如:test()),并传入相应的正则表达式作为参数。
下面是一个简单的示例,用于判断一个字符串是否为数字:```javascriptconst str = "12345";const regex = /^d+$/; //正则表达式,表示匹配全部数字if (regex.test(str)) {console.log("字符串是数字");} else {console.log("字符串不是数字");}```三、实例代码下面是一个完整的实例,用于判断用户输入的字符串是否为数字:```javascript// 获取用户输入const input = prompt("请输入一个数字:");// 判断输入是否为数字if (/^d+$/.test(input)) {console.log("输入的数字是:", input);} else {console.log("输入的不是数字,请重新输入");}```以上代码首先获取用户输入的字符串,然后使用正则表达式判断输入是否为数字。
如果输入为数字,则显示输入的数字;否则提示用户重新输入。
总结:在 JavaScript 中,我们可以使用正则表达式来判断一个字符串是否为数字。
js 正则表达式 四则运算
js 正则表达式四则运算【实用版】目录1.JavaScript 正则表达式的概念和用途2.JavaScript 正则表达式的基本语法3.JavaScript 正则表达式的四则运算4.实例:使用 JavaScript 正则表达式进行四则运算正文一、JavaScript 正则表达式的概念和用途正则表达式(Regular Expression),简称 regex,是一种强大的文本处理工具,主要用于匹配和查找文本字符串中的模式。
在 JavaScript 中,正则表达式被广泛应用于验证表单、过滤数据、提取信息等场景。
二、JavaScript 正则表达式的基本语法1.字符类:用于匹配某一类字符- [abc]:匹配 a、b 或 c- [^abc]:匹配除方括号内字符以外的任意字符- [a-zA-Z]:匹配所有英文字母- d:匹配数字,等价于 [0-9]- D:匹配非数字,等价于 [^0-9]- s:匹配空白字符(空格、制表符、换行符等)- S:匹配非空白字符- w:匹配单词字符(字母、数字、下划线),等价于 [a-zA-Z0-9_] - W:匹配非单词字符2.量词:用于指定字符或字符类出现的次数-?:出现 0 次或 1 次- *:出现 0 次或多次- +:出现 1 次或多次- {n}:出现 n 次- {n,}:出现 n 次或多次- {n,m}:出现 n 到 m 次3.边界匹配符:用于指定匹配的位置- ^:匹配字符串的开头- $:匹配字符串的结尾- b:匹配单词边界- B:匹配非单词边界4.分组和捕获:用于将正则表达式的一部分组合在一起,以便进行特定操作- (pattern):匹配 pattern 并捕获结果,可以通过引用组号获取- (?:pattern):匹配 pattern 但不捕获结果5.修饰符:用于修改正则表达式的匹配方式- i:不区分大小写- g:全局匹配(默认为局部匹配)- m:多行匹配(默认为单行匹配)三、JavaScript 正则表达式的四则运算在 JavaScript 中,正则表达式的四则运算与数学中的加减乘除类似,可以进行字符串的拼接和替换。
js的replaceall 正则表达式
js的replaceall 正则表达式在JavaScript中,String.prototype.replaceAll()方法用于在一个字符串中替换所有匹配的子串。
这个方法接受两个参数:第一个参数是你要替换的子串,第二个参数是替换后的子串。
如果你想使用正则表达式作为第一个参数,你可以这样做:javascript复制代码let str = "Hello, world! Hello, everyone!";let newStr = str.replaceAll(/hello/gi, "Hi");console.log(newStr); // "Hi, world! Hi, everyone!"在这个例子中,/hello/gi是一个正则表达式,其中:•g是一个全局标志,表示替换所有匹配的子串,而不仅仅是第一个。
•i是一个不区分大小写的标志。
因此,/hello/gi会匹配"hello","Hello","HELLO",等等。
注意:在较旧的浏览器中,可能需要使用String.prototype.replace()方法配合全局正则表达式来达到类似的效果。
例如:javascript复制代码let str = "Hello, world! Hello, everyone!";let newStr = str.replace(/hello/gi, "Hi");console.log(newStr); // "Hi, world! Hi, everyone!"在这种情况下,replace()方法使用全局的正则表达式来替换所有匹配的子串。
js 正则的方法
js 正则的方法JavaScript 中的正则表达式(RegExp)是一种强大的工具,用于在字符串中执行复杂的搜索和替换操作。
以下是一些常用的JavaScript 正则表达式方法:1.test(): 这个方法检查一个字符串是否匹配某个模式。
它会返回一个布尔值,如果字符串中存在匹配的文本,则返回true,否则返回false。
javascriptlet regex = /hello/;console.log(regex.test('hello world')); // 输出: trueconsole.log(regex.test('goodbye world')); // 输出: false2.exec(): 这个方法在一个字符串中执行正则表达式搜索,并返回一个数组。
如果没有找到匹配的文本,则返回null。
javascriptlet regex = /hello/;let result = regex.exec('hello world');console.log(result); // 输出: ["hello", index: 0, input: "helloworld", groups: undefined]3.match(): 这个方法在一个字符串中执行正则表达式搜索,并返回一个数组。
如果没有找到匹配的文本,则返回null。
与exec()方法不同,match()方法只能用于全局搜索模式(g 标志)。
javascriptlet regex = /hello/g;let result = 'hello world hello everyone'.match(regex);console.log(result); // 输出: ["hello", "hello"]4.replace(): 这个方法在一个字符串中查找与正则表达式模式匹配的文本,并用替换文本替换它。
js常用的正则表达式
js常用的正则表达式前言JavaScript中的正则表达式被广泛用于字符串的匹配和替换,可以让代码更加优雅和高效。
本文将介绍JS中常用的正则表达式及其用法,希望能对初学者有所帮助。
一、基本语法正则表达式由字面值和特殊字符两种类型组成。
字母、数字、空格等都表示字面值,而特殊符号则表示特定含义,例如/d代表数字,/s代表空格等。
正则表达式用斜杠“/”将其包裹起来。
二、常用正则表达式1. 匹配IP地址/^(\d{1,3}\.){3}\d{1,3}$/使用说明: \d表明是数字,{1,3}表明可以是一个到三个数字,\.表示点,^表示字符串开始,$表示字符串结束。
2. 匹配邮箱/^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/使用说明: \w表示字母数字下划线,[-+.]表示这些特殊字符中的一个,*表示出现零次或多次。
3. 匹配电话号码/^[1][3,4,5,7,8][0-9]{9}$/使用说明: [1]表示以1开头,[3,4,5,7,8]表示第二个数字只能是这些中的一个,[0-9]{9}表示后面必须跟九个数字。
4. 匹配URL地址/^(http|https):\/\/[a-zA-Z0-9]+[\.a-zA-Z0-9_-]*[a-zA-Z0-9]+(\/\S*)?$/使用说明: (http|https)表示http或https,\/\/表示两个斜杠,[a-zA-Z0-9]表示字母数字任意一个,+表示一个或多个,[\.a-zA-Z0-9_-]*表示出现零次或多次,\/表示斜杠,\S表示任意一个非空白字符。
5. 匹配HTML标签/<\/?[^>]+>/gi使用说明: \?表示出现零次或一次,[^>]表示不是大于号的字符,+表示一个或多个,/i使匹配忽略大小写,/g表示全局匹配。
6. 匹配中文字符/[\u4e00-\u9fa5]/使用说明: [\u4e00-\u9fa5]表示从\u4e00到\u9fa5这个区间的所有字符。
JS常用正则表达式总结【经典】
JS常⽤正则表达式总结【经典】本⽂实例讲述了JS常⽤正则表达式。
分享给⼤家供⼤家参考,具体如下:在项⽬中个⼈写的⼀个常⽤验证的正则表达式:(仅供参考)//定义两个全局变量var reg;var errorInfo;//输⼊的数字类型必须是int型,正负整数都可以function validate_integer(text,value){reg=/^[-\+]?\d+$/;errorInfo=text+" "+value+" 只能是整数,请核实重新输⼊!";verifyByReg(value,reg,errorInfo);}//输⼊的数字类型必须是double型,保留的⼩数位数只能是2位,可以为正负function validate_double(text,value){reg=/^[-\+]?([1-9](\d+)?|0)(\.\d{2})$/;errorInfo=text+" "+value+" 只能保留2为⼩数,请核实重新输⼊";verifyByReg(value,reg,errorInfo);}//输⼊的必须是全是数字类型型,不能出现其他字符function validate_number(text,value){reg=/^\d+$/;errorInfo=text+" "+value+" 只能是数字,请核实重新输⼊";verifyByReg(value,reg,errorInfo);}//验证输⼊n位的数值类型function validate_number_n(text,value,n){reg=eval("/^\\d{"+n+"}$/");errorInfo=text+" "+value+" 只能是"+n+"位数字,请核实重新输⼊";verifyByReg(value,reg,errorInfo);}//验证有两位⼩数的正实数function validate_decimal_two(text,value){reg=/^([1-9](\d+)?|0)(.[0-9]{2})?$/;errorInfo=text+" "+value+" 只能是保留2位⼩数的正数,请核实重新输⼊";verifyByReg(value,reg,errorInfo);}//验证⾮零的正整数function validate_number_positive(text,value){reg=/^\+?[1-9][0-9]*$/;errorInfo=text+" "+value+" 只能是⾮0的正整数,请核实重新输⼊";verifyByReg(value,reg,errorInfo);}//验证⾮零的负整数function validate_number_negative(text,value){reg=/^[-][1-9][0-9]*$/;errorInfo=text+" "+value+" 只能是⾮0的负整数,请核实重新输⼊";verifyByReg(value,reg,errorInfo);}//验证⾮负整数,可以为0function validate_positive_haszero(text,value){reg=/^[1-9](\d+)?|0$/;errorInfo=text+" "+value+" 只能是是0或正整数,请核实重新输⼊";verifyByReg(value,reg,errorInfo);}//验证⾮正整数,可以为0function validate_negative_haszero(text,value){reg=/^\-[1-9](\d+)?|0$/;errorInfo=text+" "+value+" 只能是是0或负整数,请核实重新输⼊";verifyByReg(value,reg,errorInfo);}//验证⾮负浮点数(正浮点数 + 0)function validate_float_notnegative(text,value){reg=/^([1-9](\d+)?|0)(\.\d+)|0$/;errorInfo=text+" "+value+" 只能是是0或正浮点数,请核实重新输⼊";verifyByReg(value,reg,errorInfo);}//验证正浮点数function validate_float_positive(text,value){reg=/^([1-9](\d+)?|0)(\.\d+)$/;errorInfo=text+" "+value+" 只能是正浮点数,请核实重新输⼊";verifyByReg(value,reg,errorInfo);}//⾮正浮点数(负浮点数 + 0)function validate_float_notpositive(text,value){reg=/^\-([1-9](\d+)?|0)(\.\d+)|0$/;errorInfo=text+" "+value+" 只能是是0或者负浮点数,请核实重新输⼊";verifyByReg(value,reg,errorInfo);}//验证负浮点数function validate_float_negative(text,value){reg=/^\-([1-9](\d+)?|0)(\.\d+)$/;errorInfo=text+" "+value+" 只能是负浮点数,请核实重新输⼊";verifyByReg(value,reg,errorInfo);}//验证正浮点数多少位⼩数function validate_float_posbit(text,value,n){reg=eval("/^(\\d+)(\\.\\d{"+n+"})$/");errorInfo=text+" "+value+" 只能是"+n+"位正浮点数,请核实重新输⼊";verifyByReg(value,reg,errorInfo);}//验证负浮点数多少位⼩数function validate_float_negbit(text,value,n){reg=eval("/^(-?\\d+)(\\.\\d{"+n+"})$/");errorInfo=text+" "+value+" 只能是"+n+"位负浮点数,请核实重新输⼊";verifyByReg(value,reg,errorInfo);}//校验⽂本是否为空function checknull(text,value){if(value=="" || typeof(value)=='undefined'){errorInfo=text+" "+value+" 不能为空,请重新输⼊!";returnInfo(errorInfo);}}//验证由26个英⽂字母组成的字符串function validate_string_letter(text,value){reg=/^[A-Za-z]+$/;errorInfo=text+" "+value+" 只能是26位不区分⼤⼩写的英⽂字母组成,请核实重新输⼊"; verifyByReg(value,reg,errorInfo);}//验证由26个英⽂字母的⼤写组成的字符串function validate_string_bigletter(text,value){reg=/^[A-Z]+$/;errorInfo=text+" "+value+" 只能是26位⼤写的英⽂字母组成,请核实重新输⼊"; verifyByReg(value,reg,errorInfo);}//验证由26个英⽂字母的⼩写组成的字符串function validate_string_smallletter(text,value){reg=/^[a-z]+$/;errorInfo=text+" "+value+" 只能是26位⼩写的英⽂字母组成,请核实重新输⼊"; verifyByReg(value,reg,errorInfo);}//验证由数字和26个英⽂字母组成的字符串function validate_string_number(text,value){reg=/^[A-Za-z0-9]+$/;errorInfo=text+" "+value+" 只能是数字和26个英⽂字母组成,请核实重新输⼊"; verifyByReg(value,reg,errorInfo);}//验证由数字、26个英⽂字母或者下划线组成的字符串function validate_string_numberandunderline(text,value){reg=/^\w+$/;errorInfo=text+" "+value+" 只能是数字、26个英⽂字母或者下划线组成,请核实重新输⼊"; verifyByReg(value,reg,errorInfo);}//验证邮箱function validate_email(value){reg=/^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/;errorInfo='邮箱 '+value+" ⽆效,请重新输⼊";verifyByReg(value,reg,errorInfo);}//验证时如果选择默认调⽤此⽅法⾦额类型,可以是正整数或保留4位有效数字的正整数/**有问题function validate_money_default(text,value){var reg=/^\d+(\.\d{4})?$/;var errorInfo=text+" "+value+" 只能是正整数或保留4位有效数字,请核实重新输⼊"; verifyByReg(value,reg,errorInfo);}**///验证输⼊的只能是中⽂function validate_chinese(text,value){reg=/^[\u4e00-\u9fa5]+$/;errorInfo=text+" "+value+" 只能是中⽂字符,请重新输⼊";verifyByReg(value,reg,errorInfo);}//验证输⼊的只能是n位的中⽂function validate_bitchinese(text,value,bit){reg=eval("/^[\\u4e00-\\u9fa5]{"+bit+"}$/");alert(reg);errorInfo=text+" "+value+" 只能是"+bit+"位中⽂字符,请重新输⼊";verifyByReg(value,reg,errorInfo);}//跟最⼤的值⽐较,此⽅法是看数字是否超出系统的上限function thanMax(text,number,max){if(number>max){errorInfo=text+" "+number+" 不能⼤于"+max+",请重新输⼊";returnInfo(errorInfo);}}//跟最⼩的值⽐较,此⽅法是看数字是否低于系统的下限function thinMin(text,number,min){if(number<min){errorInfo=text +" "+number+" 不能⼩于"+min+",请重新输⼊";returnInfo(errorInfo);}}//输⼊⽂本的字符串是否在系统的指定长度内function isLimit(text,value,length){var arr=value.split("");if(arr.length>length){errorInfo=text +" "+value+" 字符过长,请输⼊最多"+length+"位字符";returnInfo(errorInfo);}}//邮政编码的验证function validate_zipcode(value){reg=/[1-9]\d{5}(?!\d)/;errorInfo='邮政编码 '+value+" 有误,请核实重新输⼊";verifyByReg(value,reg,errorInfo);}//对数值类型的数据进⾏简单的验证和转换,因为在设置的时候没有传⼊这个参数的话就会出现js代码错误,所以应该对数值型的数据进⾏转换//⾮空字符的判定function getZeroByNull(text,value){errorInfo=text+" "+value+" 不能为空,请核实重新输⼊";if(value==null||value==''||value=='undefined'){returnInfo(errorInfo);}}//⾝份证验证,分为了两种,15位和18位function validate_IdCard(value){var size=value.split("");if(size.length==15){reg=/^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$/;//15位⾝份证验证errorInfo='位⾝份证号码 '+value+" 有误,请核实重新输⼊";}else if(size.length==18){reg=/^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X|x)$/;//18位⾝份证验证errorInfo='位⾝份证号码 '+value+" 有误,请核实重新输⼊";}else{errorInfo="请输⼊合法的⾝份证号码!";returnInfo(errorInfo);}verifyByReg(value,reg,errorInfo);}//每个验证都需要调⽤此⽅法function verifyByReg(value,reg,errorInfo){if(value!=''&®!=''){var regExp = new RegExp(reg);if(!regExp.test(value)){alert(errorInfo);throw errorInfo;}}}//不进过正则表达式验证,只需要返回信息,适合内部调⽤此⽅法function returnInfo(message){alert(message);throw message;}//许可证号⽣产企业的格式:QS 1234 2346 3456 其中空格可有可⽆///经营企业许可证的格式为: 湘010249 但是中国的省会简称可能会有三个字的,所以中⽂可以定义为1-3个function validate_license(value,type){if(type==1){reg=/^[a-zA-Z]{2}[ ]?(\d{4}[ ]?\d{4}[ ]?\d{4})$/;//⽣产企业许可证号errorInfo="⽣产许可证号 "+value+" 有误,请核实重新输⼊!";}else if(type==2){reg=/^[\u4e00-\u9fa5]{1,3}\d{6}$/;errorInfo="经营许可证号 "+value+" 有误,请核实重新输⼊!";}verifyByReg(value,reg,errorInfo);}//传真可以匹配的字符串如:+123 -999 999 ; +123-999 999 ;123 999 999 ;+123 999999等function validate_fax(value){reg=/^([+]{0,1})?\d{1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/;errorInfo="传真 "+value+" 有误,请重新输⼊!";verifyByReg(value,reg,errorInfo);}//电话号码可以输⼊:电话或者⼿机其中⼿机号码可以是(+86)、(86)+号码,也可以是号码电话的号码可以是区号+号码区号-号码号码function validate_tel(value){reg=/(^(0\d{2,3}([-|+])?)?\d{7}$)|(^(\d{3,4}([-|+])?)?\d{7,8}$)|(^([+]?(86)?[+]?)1[3-9]\d{9}$)/;errorInfo='电话号码 '+value+" 有误,请核实重新输⼊!";verifyByReg(value,reg,errorInfo);}//⽇:⼤于0⼩于等于31的正整数function validate_day(value){reg=/(^[0]?[1-9]$)|(^[1-2]\d$)|(^[3][0-1]$)/;errorInfo='⽇期 '+value+" 有误,请核实重新输⼊!";verifyByReg(value,reg,errorInfo);}//⽉:合法⽉份function validate_month(value){reg=/(^[0]?[1-9]$)|(^[1][0-2]$)/;errorInfo='⽉份 '+value+" 有误,请核实重新输⼊!";verifyByReg(value,reg,errorInfo);}//年:合法年份在这⾥合法的年份为公元1000年⾄公元2999年function validate_year(value){reg=/^[1-2]\d{3}$/;errorInfo='年份 '+value+" 有误,请核实重新输⼊!";verifyByReg(value,reg,errorInfo);}//百分⽐:合法百分⽐(0-100之前的数字)function validate_percentage(text,value){reg=/(^[1-9](\d)?(\.\d+)?$)|(^0(\.\d+)?$)|(^100$)/;errorInfo=text +" "+value+" 有误,请输⼊0到100的数字!";verifyByReg(value,reg,errorInfo);}//系数:⼩于等于1的正数在这⾥系数的⼩数点后⾯也是2位function validate_modulus(text,value){reg=/^[0](\.\d{2})$|^[1](\.[0]{2})?$/;errorInfo=text+" "+value+" 有误,请输⼊⼩于0到1的数字!";verifyByReg(value,reg,errorInfo);}//验证⾮负的正数,包含了正整数和正浮点数function validate_posnumhaszero(text,value){checknull(text,value);reg=/^[1-9](\d+)?(\.\d+)?$|^0(\.\d+)?$/;errorInfo=text+" "+value+" 有误,请输⼊⼤于或等于0 的数字!";verifyByReg(value,reg,errorInfo);}//验证⾮正的负数,包含了负整数和负浮点数function validate_negnumhaszero(text,value){checknull(text,value);reg=/^[-][1-9](\d+)?(\.\d+)?$|^[-]0(\.\d+)?$/;errorInfo=text+" "+value+" 有误,请输⼊⼩于或等于0 的数字!";verifyByReg(value,reg,errorInfo);}//验证正数,包含了正整数和正浮点数function validate_posnum(text,value){checknull(text,value);reg=/^[1-9](\d+)?(\.\d+)?$|^0(\.\d+)$/;errorInfo=text+" "+value+" 有误,请输⼊⼤于0 的数字!";verifyByReg(value,reg,errorInfo);}//验证负数,包含了负整数和负浮点数function validate_negnum(text,value){checknull(text,value);reg=/^[-][1-9](\d+)?(\.\d+)?$|^[-]0(\.\d+)$/;errorInfo=text+" "+value+" 有误,请输⼊⼩于0 的数字!";verifyByReg(value,reg,errorInfo);}//验证数,包括所有的数值,正数、负数、正浮点数、负浮点数function validate_allnum(text,value){checknull(text,value);reg=/^[-|+]?[1-9](\d+)?(\.\d+)?$|^[-|+]?0(\.\d+)?$/;errorInfo=text+" "+value+" 有误,请输⼊数字!";verifyByReg(value,reg,errorInfo);}PS:这⾥再为⼤家提供2款⾮常⽅便的正则表达式⼯具供⼤家参考使⽤:更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》、《》及《》希望本⽂所述对⼤家JavaScript程序设计有所帮助。
js泛域名正则
js泛域名正则全文共四篇示例,供读者参考第一篇示例:泛域名正则表达式的基本形式如下所示:``` javascript/^((\*\.)?([A-Za-z0-9-]+\.){1,}[A-Za-z0-9-]+)/```该正则表达式可以匹配包含通配符的泛域名,例如*,等形式。
让我们来逐步解释这个正则表达式的各个部分。
- `^` 表示匹配字符串的开始。
- `(\*\.)?` 表示匹配零个或一个星号(*)加上一个点(.)的字符串,用于匹配泛域名的通配符部分。
- `([A-Za-z0-9-]+\.){1,}` 表示匹配一个或多个由字母、数字和连字符组成的子域名,后面跟着一个点(.)。
- `[A-Za-z0-9-]+` 表示匹配一个由字母、数字和连字符组成的顶级域名。
- `` 表示匹配字符串的结束。
这个正则表达式可以灵活地匹配各种形式的泛域名。
接下来,让我们看一个示例,如何使用这个正则表达式来匹配泛域名。
除了使用正则表达式进行泛域名匹配之外,JavaScript还提供了一些内置方法来处理泛域名。
可以使用`String.prototype.includes()`方法来检查一个域名是否匹配特定的泛域名。
这个方法可以更直观地进行泛域名的匹配,如下所示:泛域名正则表达式在JavaScript中的应用场景非常广泛,可以用于域名匹配、域名解析等方面。
借助泛域名正则表达式,我们可以更方便地处理包含通配符的泛域名,提高代码的可读性和可维护性。
希望本文对大家有所帮助,欢迎大家多多探讨交流。
第二篇示例:泛域名是一种特殊的域名形式,它允许用通配符表示多个子域名。
通常,泛域名中会使用星号(*)作为通配符,表示任意子域名。
*可以匹配、、等多个子域名。
在正则表达式中,我们可以使用特定的语法来表示泛域名,例如:/^*/。
这个正则表达式使用了星号通配符来匹配任意子域名,然后固定了域名后缀为。
这样,我们就可以通过这个正则表达式来验证一个字符串是否符合泛域名的格式。
17种常用的JS正则表达式非负浮点数非负正数
17种常⽤的JS正则表达式⾮负浮点数⾮负正数<input type='text' id='SYS_PAGE_JumpPage' name='SYS_PAGE_JumpPage' size='3' maxlength='5'onkeyup='this.value=this.value.replace(/[^1-9]\D*$/,"")' ondragenter="return false" onpaste="return!clipboardData.getData('text').match(/\D/)"" style="ime-mode:disabled;">1.只能输⼊数字和英⽂的:<input onkeyup="value=value.replace(/[\W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))" ID="Text1" NAME="Text1">2.只能输⼊数字的:<input onkeyup="value=value.replace(/[^\d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))" ID="Text2" NAME="Text2">3.只能输⼊全⾓的:<input onkeyup="value=value.replace(/[^\uFF00-\uFFFF]/g,'')"onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,''))" ID="Text3" NAME="Text3"> 4.只能输⼊汉字的:<input onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')"onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))" ID="Text4" NAME="Text4"> 5.邮件地址验证:var regu = "^(([0-9a-zA-Z]+)|([0-9a-zA-Z]+[_.0-9a-zA-Z-]*[0-9a-zA-Z]+))@([a-zA-Z0-9-]+[.])+([a-zA-Z]{2}|net|NET|com|COM|gov|GOV|mil|MIL|org|ORG|edu|EDU|int|INT)$"var re = new RegExp(regu);if (s.search(re) != -1) {return true;} else {window.alert ("请输⼊有效合法的E-mail地址!")return false;}6.⾝份证:"^\\d{17}(\\d|x)$"7.17种正则表达式"^\\d+$" //⾮负整数(正整数 + 0)"^[0-9]*[1-9][0-9]*$" //正整数"^((-\\d+)|(0+))$" //⾮正整数(负整数 + 0)"^-[0-9]*[1-9][0-9]*$" //负整数"^-?\\d+$" //整数"^\\d+(\\.\\d+)?$" //⾮负浮点数(正浮点数 + 0)"^(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*))$" //正浮点数"^((-\\d+(\\.\\d+)?)|(0+(\\.0+)?))$" //⾮正浮点数(负浮点数 + 0)"^(-(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*)))$" //负浮点数"^(-?\\d+)(\\.\\d+)?$" //浮点数"^[A-Za-z]+$" //由26个英⽂字母组成的字符串"^[A-Z]+$" //由26个英⽂字母的⼤写组成的字符串"^[a-z]+$" //由26个英⽂字母的⼩写组成的字符串"^[A-Za-z0-9]+$" //由数字和26个英⽂字母组成的字符串"^\\w+$" //由数字、26个英⽂字母或者下划线组成的字符串"^[\\w-]+(\\.[\\w-]+)*@[\\w-]+(\\.[\\w-]+)+$" //email地址"^[a-zA-z]+://(\\w+(-\\w+)*)(\\.(\\w+(-\\w+)*))*(\\?\\S*)?$" //url=============================================1.取消按钮按下时的虚线框在input⾥添加属性值 hideFocus 或者 HideFocus=true2.只读⽂本框内容在input⾥添加属性值 readonly3.防⽌退后清空的TEXT⽂档(可把style内容做做为类引⽤)<INPUT style=behavior:url(#default#savehistory); type=text id=oPersistInput>4.ENTER键可以让光标移到下⼀个输⼊框<input onkeydown="if(event.keyCode==13)event.keyCode=9" >5.只能为中⽂(有闪动)<input onkeyup="value="/value.replace(/[" -~]/g,’’)" onkeydown="if(event.keyCode==13)event.keyCode=9">6.只能为数字(有闪动)<input onkeyup="value="/value.replace(/["^\d]/g,’’)"onbeforepaste="clipboardData.setData(’text’,clipboardData.getData(’text’).replace(/[^\d]/g,’’))">7.只能为数字(⽆闪动)<input ime-mode:disabled" onkeydown="if(event.keyCode==13)event.keyCode=9" onKeyPress="if ((event.keyCode<48 || event.keyCode>57)) event.returnValue=false">8.只能输⼊英⽂和数字(有闪动)<input onkeyup="value="/value.replace(/[\W]/g,"’’)"onbeforepaste="clipboardData.setData(’text’,clipboardData.getData(’text’).replace(/[^\d]/g,’’))">9.屏蔽输⼊法<input type="text" name="url" ime-mode:disabled" onkeydown="if(event.keyCode==13)event.keyCode=9">10. 只能输⼊数字,⼩数点,减号(-)字符(⽆闪动)<input onKeyPress="if (event.keyCode!=46 && event.keyCode!=45 && (event.keyCode<48 || event.keyCode>57)) event.returnValue=false">11. 只能输⼊两位⼩数,三位⼩数(有闪动)<input maxlength=9 onkeyup="if(value.match(/^\d{3}$/))value="/value.replace(value,parseInt(value/10))";value="/value.replace(/\.\d*\./g,’."’)" onKeyPress="if((event.keyCode<48 || event.keyCode>57) && event.keyCode!=46 && event.keyCode!=45 || value.match(/^\d{3}$/) || /\.\d{3}$/.test(value)) {event.returnValue=false}" id=text_kfxe name=text_kfxe>。
利用js正则表达式校验正数、负数、和小数
利⽤js正则表达式校验正数、负数、和⼩数话不多少,直接附上代码实例,仅供参考<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="/1999/xhtml"><head><title></title><script type="text/javascript">function validation() {var val = document.getElementById("txtNumber").value;var regu = /^(\-|\+)?\d+(\.\d+)?$/;if (val != "") {if (!regu.test(val)) {document.getElementById("labResult").style.color = "red";document.getElementById("labResult").innerHTML = "验证失败!";} else {document.getElementById("labResult").style.color = "green";document.getElementById("labResult").innerHTML = "验证成功!";}}}</script></head><body><input id="txtNumber" name="txtNumber" type="text" /><input id="btnValidation" name="btnValidation" type="button" value="校验" onclick="validation()" />验证结果:<label id="labResult" ></label></body></html>以上就是本⽂的全部内容,希望本⽂的内容对⼤家的学习或者⼯作能带来⼀定的帮助,如果有疑问⼤家可以留⾔交流,同时也希望多多⽀持!。
JS使用正则表达式获取小括号、中括号及花括号内容的方法示例
JS使⽤正则表达式获取⼩括号、中括号及花括号内容的⽅法⽰例本⽂实例讲述了JS使⽤正则表达式获取⼩括号、中括号及花括号内容的⽅法。
分享给⼤家供⼤家参考,具体如下:正则表达式的() [] {}有不同的意思。
() 是为了提取匹配的字符串。
表达式中有⼏个()就有⼏个相应的匹配字符串。
(\s*)表⽰连续空格的字符串。
[]是定义匹配的字符范围。
⽐如 [a-zA-Z0-9] 表⽰相应位置的字符要匹配英⽂字符和数字。
[\s*]表⽰空格或者*号。
{}⼀般⽤来表⽰匹配的长度,⽐如 \s{3} 表⽰匹配三个空格,\s[1,3]表⽰匹配⼀到三个空格。
(0-9) 匹配 '0-9′本⾝。
[0-9]* 匹配数字(注意后⾯有 *,可以为空)[0-9]+ 匹配数字(注意后⾯有 +,不可以为空){1-9} 写法错误。
[0-9]{0,9} 表⽰长度为 0 到 9 的数字字符串。
⼩括号是⽤于将基本的单元合成⼀个⼤的单元,⽽中括号就是将多个基本单元组成⼀个选择域,表⽰其中⼀个的意思。
例⼦:⼩括号例⼦1、我们想匹配123这个整体(123)就是匹配"123"这个整体,⼤括号⽽[123]就是匹配1/2/3(1或者2或者3)再举个⼩编碰到的⼀个问题例如我们想匹配 多个替换<p> </p>中间多个 的时候先⽤中括号[]<p>[ ]*</p>匹配内容的就如下图所⽰那下⾯⽤⼩括号试试()<p>( )*</p>就是我们预想的效果。
其实匹配的正则⽐较好的是这个,⾥⾯万⼀空字符肯定就不⾏了<p>(\s|\ \;| | | c2 a0)*</p>JS 正则表达式获取⼩括号中括号花括号内的内容<!DOCTYPE html><html><head><meta charset="utf-8" /><title> JS获取括号内容</title></head><body><script type="text/javascript">var str="123{xxxx}456[我的]789123[你的]456(1389090)789";var regex1 = /\((.+?)\)/g; // () ⼩括号var regex2 = /\[(.+?)\]/g; // [] 中括号var regex3 = /\{(.+?)\}/g; // {} 花括号,⼤括号// 输出是⼀个数组console.log(str.match(regex1));console.log(str.match(regex2));console.log(str.match(regex3));</script></body></html>附:JAVA正则匹配语句regex = "(?<=\\[)(\\S+)(?=\\])"PS:这⾥再为⼤家提供2款⾮常⽅便的正则表达式⼯具供⼤家参考使⽤:更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》、《》及《》希望本⽂所述对⼤家JavaScript程序设计有所帮助。
js验证正整数的正则表达式
js验证正整数的正则表达式在JavaScript中,可以使用正则表达式验证输入的字符串是否为正整数。
正整数是指不含小数点、负号或其他非数字字符的整数。
以下是一个简单的JavaScript正则表达式,用于验证字符串是否为正整数:```javascript/^[1-9]d*$/```这个正则表达式的含义是:- `^` 表示匹配字符串的开头。
- `[1-9]` 表示匹配数字1到9中的任意一个。
- `d*` 表示匹配0个或多个任意数字。
- `$` 表示匹配字符串的结尾。
因此,这个正则表达式表示匹配以数字1到9开头,后面跟着0个或多个数字的字符串,即正整数。
以下是一个简单的JavaScript函数,用于验证输入的字符串是否为正整数:```javascriptfunction isPositiveInteger(str) {return /^[1-9]d*$/.test(str);}```该函数接受一个字符串参数,并使用正则表达式测试它是否为正整数。
如果字符串是正整数,则返回`true`,否则返回`false`。
使用示例:```javascriptconsole.log(isPositiveInteger('123')); // trueconsole.log(isPositiveInteger('-123')); // falseconsole.log(isPositiveInteger('1.23')); // falseconsole.log(isPositiveInteger('0')); // falseconsole.log(isPositiveInteger('abc')); // false```需要注意的是,该函数只能验证字符串是否为正整数,无法验证是否超过某个特定的范围。
如果需要验证数值是否在特定范围内,可以先使用该函数判断字符串是否为正整数,然后再将字符串转换为数字进行进一步的验证。
js正则匹配所有英文符号的方法
js正则匹配所有英文符号的方法如果你想使用JavaScript正则表达式匹配所有的英文符号,包括字母、数字、空格、标点符号等,可以使用以下正则表达式:```javascript/[\S\s]/g```这个正则表达式使用了一个字符类(character class)`[\S\s]`,其中`\S`表示任何非空白字符(non-whitespace character),`\s`表示任何空白字符(whitespace character)。
`g`标志表示全局匹配,即匹配所有符合条件的字符。
下面是一个使用这个正则表达式的JavaScript代码示例:```javascriptconst regex = /[\S\s]/g;const str = "Hello, world! 123";const matches = str.match(regex);console.log(matches); // 输出["H", "e", "l", "l", "o", ",", " ", "w", "o", "r", "l", "d", "!", "1", "2", "3"]```在这个示例中,我们使用`match()`方法将正则表达式应用于字符串`str`,并将结果存储在`matches`变量中。
然后,我们使用`console.log()`将结果输出到控制台。
js中判断数字字母中文的正则表达式 (实例)
for(var i=0;i var c = str.charAt(i); if((c<"a"||c>"z")&&(c<"A"||c>"Z")){ return false; } } return true; } /* 空格判断,当包含有空格返回 false,当不包含一个空格返回 true ""不能被判断 */ function notInSpace(str){ if(""==str){ return false; } var badChar =" "; badChar += " "; for(var i=0;i var c = str.charAt(i);//字符串 str 中的字符 if(badChar.indexOf(c) > -1){ return false; } } return true; } /* **号判断函数,返回 true 表示是**号,返回 false 表示不符合规范 */ function isFPH(str){ if(""==str){ return false; } for(var i=0;i var c = str.charAt(i); if((c < "0" || c > "9") && (c!="-")&&(c!=",")){ return false; } } return true; } /* 电话判断函数,允许“数字” 、 “;” 、 “-” 、 “ (” 、 ”)“, true 表示是电话号码 */ function isTelephone(str){ var trueChar = "()-;1234567890";
JS的正则表达式和具体说明详解参考,例题
}
</PRE>
<BR>
<BR>//校验邮政编码
<BR><PRE class=java name="code">function isPostalCode(s)
{
//var patrn=/^[a-zA-Z0-9]{3,12}$/;
"^[A-Za-z0-9_]*$"
</PRE>
<BR>
<BR><SPAN style="FONT-SIZE: 18pt">正则表达式使用详解</SPAN>
<BR>
<BR>简介
<BR>
<BR>简单的说,正则表达式是一种可以用于模式匹配和替换的强有力的工具。其作用如下:
JS的正则表达式
//校验是否全由数字组成
function isDigit(s)
{
var patrn=/^[0-9]{1,20}$/;
if (!patrn.exec(s)) return false
return true
}
//校验登录名:只能输入5-20个以字母开头、可带数字、“_”、“.”的字串
{
var patrn=/^[^`~!@#$%^&*()+=|\\\][\]\{\}:;'\,.<>/?]{1}[^`~!@$%^&()+=|\\\]
[\]\{\}:;'\,.<>?]{0,19}$/;
JS只能输入数字或数字和字母等的正则表达式
JS只能输⼊数字或数字和字母等的正则表达式JS判断只能是数字和⼩数点0.不能输⼊中⽂1)<input onpaste="return false;" type="text" name="textfield" style="width:400px; ime-mode:disabled" value="">2)复制代码代码如下:<script>function chkIt(frm){if (frm.n1.value.length>0&&frm.n1.value.match(/[ 01- FF]*/)==false){alert('n1不能输⼊中⽂!')frm.n1.focus();return false;}}</script><body><form onsubmit="return chkIt(this)"><input name="n1"><input name="n2"><input name="smt" type="submit" value="提交"></form></body>1.⽂本框只能输⼊数字代码(⼩数点也不能输⼊)<input onkeyup="this.value=this.value.replace(/\D/g,'')" onafterpaste="this.value=this.value.replace(/\D/g,'')">2.只能输⼊数字,能输⼩数点.<input onkeyup="if(isNaN(value))execCommand('undo')" onafterpaste="if(isNaN(value))execCommand('undo')"><input name=txt1 onchange="if(/\D/.test(this.value)){alert('只能输⼊数字');this.value='';}">3.数字和⼩数点⽅法⼆<input type=text t_value="" o_value="" onkeypress="if(!this.value.match(/^[\+\-]?\d*?\.?\d*?$/))this.value=this.t_value;elsethis.t_value=this.value;if(this.value.match(/^(?:[\+\-]?\d+(?:\.\d+)?)?$/))this.o_value=this.value" onkeyup="if(!this.value.match(/^[\+\-]?\d*?\.?\d*? $/))this.value=this.t_value;else this.t_value=this.value;if(this.value.match(/^(?:[\+\-]?\d+(?:\.\d+)?)?$/))this.o_value=this.value"onblur="if(!this.value.match(/^(?:[\+\-]?\d+(?:\.\d+)?|\.\d*?)?$/))this.value=this.o_value;else{if(this.value.match(/^\.\d+$/))this.value=0+this.value;if(this.value.match(/^\.$/))this.value=0;this.o_value=this.value}"> 4.只能输⼊字母和汉字<input onkeyup="value=value.replace(/[\d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[\d]/g,''))" maxlength=10 name="Numbers">5.只能输⼊英⽂字母和数字,不能输⼊中⽂<input onkeyup="value=value.replace(/[^\w\.\/]/ig,'')">6.只能输⼊数字和英⽂<font color="Red">chun</font><input onKeyUp="value=value.replace(/[^\d|chun]/g,'')">7.⼩数点后只能有最多两位(数字,中⽂都可输⼊),不能输⼊字母和运算符号:<input onKeyPress="if((event.keyCode<48 || event.keyCode>57) && event.keyCode!=46 || /\.\d\d$/.test(value))event.returnValue=false">8.⼩数点后只能有最多两位(数字,字母,中⽂都可输⼊),可以输⼊运算符号:<input onkeyup="this.value=this.value.replace(/^(\-)*(\d+)\.(\d\d).*$/,'$1$2.$3')">禁⽌特殊字符:onKeyPress="if(event.keyCode < 45 || event.keyCode > 57 ) event.returnValue = false;"只能输⼊汉字:<input onkeyup="value=value.replace(/[^/u4E00-/u9FA5]/g,'')"onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^/u4E00-/u9FA5]/g,''))">style="ime-mode:disabled"禁⽌汉字输⼊法只能输⼊数字:<input onkeyup="value=value.replace(/[^/d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^/d]/g,''))">只能输⼊英⽂和数字:<input onkeyup="value=value.replace(/[/W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^/d]/g,''))">控制输⼊框只能输⼊⽂字或数字,也可以不允许输⼊特殊字符这⾥不允许输⼊如下字符: (像 ^&* 等)<br><textarea rows=2 cols=20 name=comments onKeypress="if ((event.keyCode > 32 && event.keyCode < 48) || (event.keyCode > 57 &&event.keyCode < 65) || (event.keyCode > 90 && event.keyCode < 97)) event.returnValue = false;">只禁⽌空格输⼊onkeyup="value=value.replace(//s/g,'')"onkeydown="if(event.keyCode==32) return false"只能输⼊中⽂和英⽂:onkeyup="value=value.replace(/[^/a-zA-Z/u4E00-/u9FA5]/g,'')"onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^/a-zA-Z/u4E00-/u9FA5]/g,''))"不允许输⼊特殊字符和空格:<input id="code" onkeypress="return ValidateSpecialCharacter();" onblur="validate(this)"/>————————————————————————————————————————不能为空<input onblur="if(this.value.replace(/^ +| +$/g,'')=='')alert('不能为空!')">判断字符由字母和数字,下划线,点号组成.且开头的只能是下划线和字母/^([a-zA-z_]{1})([\w]*)$/g.test(str)只能输⼊数字<input name="text" type="text" id="NewPage" onKeyUp="value=value.replace(/\D/g,'')" onafterpaste="value=value.replace(/\D/g,'')" >只能输⼊中⽂<input type="text" onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')">只能输⼊英⽂<input type="text" onkeyup="value=value.replace(/[^\a-\z\A-\Z]/g,'')"><input type="text" onkeyup="value=value.replace(/[^a-zA-Z]/g,'')">--------------------------------------------------------------------------------------------------------------------只能输⼊中⽂、英⽂、数字、@符号和.符号<input type="text" onkeyup="value=value.replace(/[^\a-\z\A-\Z0-9\u4E00-\u9FA5\@\.]/g,'')">只允许输⼊英⽂,且不能粘贴也⽆法弹出粘贴菜单<input type="text" onkeyup="value=value.replace(/[^\a-\z\A-\Z]/g,'')" onkeydown="fncKeyStop(event)" onpaste="return false" oncontextmenu = "return false"/>只能输⼊数字和点号(注意:在[^\d\.]⾥的d不能写成⼤写D,否则就变成除了数字以外的所有字符)<input name="price" type="text" size="8" maxlength="8" onkeyup="value=value.replace(/[^\d\.]/g,'')" >总⽽⾔之:先在<input>⾥输⼊onkeyup="value=value.replace(/[^\X]/g,'')" 然后在(/[\X]/g,'')⾥的X换成你想输⼊的代码就可以了中⽂:u4E00-u9FA5数字:d、0-9英⽂:a-z、A-Z其它符号@,点或其它符号.也可以多个,⽤\隔开就⾏了.例如:中、英⽂和数字加@符号加点符号:\a-\z\A-\Z0-9\u4E00-\u9FA5\@\.若想在⽂本框⾥不能右键弹出菜单和不能粘贴进复制的信息的话就要在<input>⾥输⼊ onKeyDown="fncKeyStop(event)" onpaste="return false" oncontextmenu="return false;"---------------------------------------------------------------------------------------------------------------------------------------其⼀,只允许输⼊数字和⼩数点。
js百分数正则表达式
js百分数正则表达式在JavaScript中,如果你想匹配一个表示百分数的字符串(例如"50%"),你可以使用以下的正则表达式:javascript/^\d+(\.\d+)?%$/这个正则表达式的组成部分如下:•^:匹配字符串的开始。
•\d+:匹配一个或多个数字。
•(\.\d+)?:可选地匹配一个小数点后跟一个或多个数字。
这允许匹配像"50.5%" 这样的百分数。
•%:匹配百分号。
•$:匹配字符串的结束。
你可以使用这个正则表达式与JavaScript的match()方法或test()方法来检查一个字符串是否是有效的百分数。
例如:javascriptconst regex = /^\d+(\.\d+)?%$/;console.log("50%".match(regex)); // 输出 ["50%", index: 0,input: "50%", groups: undefined]console.log("50.5%".match(regex)); // 输出 ["50.5%", index: 0, input: "50.5%", groups: undefined]console.log("abc%".match(regex)); // 输出 nullconsole.log("50".match(regex)); // 输出 null或者:javascriptconst regex = /^\d+(\.\d+)?%$/;console.log(regex.test("50%")); // 输出 trueconsole.log(regex.test("50.5%")); // 输出 trueconsole.log(regex.test("abc%")); // 输出 falseconsole.log(regex.test("50")); // 输出 false这样,你就可以检查一个字符串是否是一个有效的百分数表示了。
js中判断数字字母中文的正则表达式(实例)
js中判断数字字母中⽂的正则表达式(实例)/*判断指定的内容是否为空,若为空则弹出警告框*/function isEmpty(theValue, strMsg){if(theValue==""){alert(strMsg+"不能为空!");return true;}return false;}/*中⽂判断函数,允许⽣僻字⽤英⽂“*”代替返回true表⽰是符合条件,返回false表⽰不符合*/function isChinese(str){var badChar ="ABCDEFGHIJKLMNOPQRSTUVWXYZ";badChar += "abcdefghijklmnopqrstuvwxyz";badChar += "0123456789";badChar += " "+" ";//半⾓与全⾓空格badChar += "不包含*或.的英⽂符号if(""==str){return false;}for(var i=0;i var c = str.charAt(i);//字符串str中的字符if(badChar.indexOf(c) > -1){return false;}}return true;}/*数字判断函数,返回true表⽰是全部数字,返回false表⽰不全部是数字*/function isNumber(str){if(""==str){return false;}var reg = /\D/;return str.match(reg)==null;}/*判断给定的字符串是否为指定长度的数字是返回true,不是返回false*/function isNumber_Ex(str,len){if(""==str){return false;}if(str.length!=len){return false;}if(!isNumber(str)){return false;}return true;}/*money判断函数,允许第⼀位为"-"来表⽰⽋钱function isMoney(str){if(""==str){return false;}for(var i=0;i var c = str.charAt(i);if(i==0){if(c!="-"&&(c<"0"||c>"9")){return false;}else if(c=="-"&&str.length==1){return false;}}else if(c < "0" || c > "9"){return false;}}return true;}/*英⽂判断函数,返回true表⽰是全部英⽂,返回false表⽰不全部是英⽂*/function isLetter(str){if(""==str){return false;}for(var i=0;i var c = str.charAt(i);if((c<"a"||c>"z")&&(c<"A"||c>"Z")){return false;}}return true;}/*空格判断,当包含有空格返回false,当不包含⼀个空格返回true ""不能被判断*/function notInSpace(str){if(""==str){return false;}var badChar =" ";badChar += " ";for(var i=0;i var c = str.charAt(i);//字符串str中的字符if(badChar.indexOf(c) > -1){return false;}}return true;}/***号判断函数,返回true表⽰是**号,返回false表⽰不符合规范*/function isFPH(str){if(""==str){return false;}for(var i=0;i var c = str.charAt(i);if((c < "0" || c > "9") && (c!="-")&&(c!=",")){return false;}}/*电话判断函数,允许“数字”、“;”、“-”、“(”、”)“,true表⽰是电话号码*/function isTelephone(str){var trueChar = "()-;1234567890";if(""==str){return false;}for(var i=0;i var c = str.charAt(i);//字符串str中的字符if(trueChar.indexOf(c) == -1) return false;}return true;}/**学制可以为1-7,也可以为3.5这种形式,不能超过7年或者低于1年*/function isXZ(str){if(""==str){return false;}var reg = /^[1-6](\.5)?$/;var r = str.match(reg);if(null!=r){return true;}else{if(str=="7"){return true;}else{return false;}}}/*判断证书编号是否符合要求,证书编号包含中⽂、数字、⼤⼩写字母、(、)、- 是返回true,不是返回false*/function isZSBH(str){if(""==str){return false;}for(var i=0;i var c = str.charAt(i);alpha = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";alpha += "abcdefghijklmnopqrstuvwxyz";alpha += "()-";if(!isChinese(c)&&!isNumber(c)&&alpha.indexOf(c)==-1){return false;}}return true;}/*⾝份证判断函数,是返回true,不是返回false15位数字,18位数字或者最后⼀位为X(⼤写)*/function isSFZ(str){if(""==str){return false;}if(str.length!=15&&str.length!=18){//⾝份证长度不正确if(str.length==15){if(!isNumber(str)){return false;}}else{str1 = str.substring(0,17);str2 = str.substring(17,18);alpha = "X0123456789";if(!isNumber(str1)||alpha.indexOf(str2)==-1){return false;}}return true;}/*得到今天的年,⽉,⽇调⽤⽅法:today = new getToday(); 则today.year为今天的年以此类推*/function getToday(){this.now = new Date();this.year = this.now.getFullYear();this.month = this.now.getMonth();this.day = this.now.getDate();}js判断数字,字母,中⽂1.var reg = /^(\w|[\u4E00-\u9FA5])*$/;if(arr=username.match(reg)){ti=1;return ture;}else{alert("⽤户名只允许为英⽂,数字和汉字的混合,\n请检查是否前后有空格或者其他符号");ti=0;return false;}2.利⽤正则表达式限制⽹页表单⾥的⽂本框输⼊内容:⽤正则表达式限制只能输⼊中⽂:onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))" ⽤正则表达式限制只能输⼊全⾓字符: onkeyup="value=value.replace(/[^\uFF00-\uFFFF]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,''))" ⽤正则表达式限制只能输⼊数字:onkeyup="value=value.replace(/[^\d]/g,'')"onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"⽤正则表达式限制只能输⼊数字和英⽂:onkeyup="value=value.replace(/[\W]/g,'')"onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"数字<script>function check(){if(!isNaN(document.all.form.str.value)){alert("数字");}</script>字母<script>var str = /[_a-zA-Z]/;if(str.test(document.all.form.str.value)){alert("字母");}}</script><form name="form" action="" onsubmit="return check();"> <input type=text name=str><input type=submit><form>---------------------------------------------------/*** ⼀些常⽤的javascript函数(⽅法)** 为便于使⽤,均书写成String对象的⽅法* 把他保存为.js⽂件,可⽅便的扩展字符串对象的功能** ⽅法名功能* ----------- --------------------------------* Trim 删除⾸位空格* Occurs 统计指定字符出现的次数* isDigit 检查是否由数字组成* isAlpha 检查是否由数字字母和下划线组成* isNumber 检查是否为数* lenb 返回字节数* isInChinese 检查是否包含汉字* isEmail 简单的email检查* isDate 简单的⽇期检查,成功返回⽇期对象* isInList 检查是否有列表中的字符字符* isInList 检查是否有列表中的字符字符*//*** 删除⾸尾空格 ***/String.prototype.Trim = function() {return this.replace(/(^\s*)|(\s*$)/g, "");}/*** 统计指定字符出现的次数 ***/String.prototype.Occurs = function(ch) {// var re = eval("/[^"+ch+"]/g");// return this.replace(re, "").length;return this.split(ch).length-1;}/*** 检查是否由数字组成 ***/String.prototype.isDigit = function() {var s = this.Trim();return (s.replace(/\d/g, "").length == 0);}/*** 检查是否由数字字母和下划线组成 ***/String.prototype.isAlpha = function() {return (this.replace(/\w/g, "").length == 0);}/*** 检查是否为数 ***/String.prototype.isNumber = function() {var s = this.Trim();return (s.search(/^[+-]?[0-9.]*$/) >= 0);}/*** 返回字节数 ***/String.prototype.lenb = function() {return this.replace(/[^ 00- ff]/g,"**").length;}String.prototype.isInChinese = function() {return (this.length != this.replace(/[^ 00- ff]/g,"**").length);}/*** 简单的email检查 ***/String.prototype.isEmail = function() { var strr;var mail = this; var re = /(\w+@\w+\.\w+)(\.{0,1}\w*)(\.{0,1}\w*)/i; re.exec(mail); if(RegExp.$3!="" && RegExp.$3!="." && RegExp.$2!=".") strr = RegExp.$1+RegExp.$2+RegExp.$3; else if(RegExp.$2!="" && RegExp.$2!=".")strr = RegExp.$1+RegExp.$2; else strr = RegExp.$1; return (strr==mail);}/*** 简单的⽇期检查,成功返回⽇期对象 ***/String.prototype.isDate = function() {var p;var re1 = /(\d{4})[年./-](\d{1,2})[⽉./-](\d{1,2})[⽇]?$/;var re2 = /(\d{1,2})[⽉./-](\d{1,2})[⽇./-](\d{2})[年]?$/;var re3 = /(\d{1,2})[⽉./-](\d{1,2})[⽇./-](\d{4})[年]?$/;if(re1.test(this)) {p = re1.exec(this);return new Date(p[1],p[2],p[3]);}if(re2.test(this)) {p = re2.exec(this);return new Date(p[3],p[1],p[2]);}if(re3.test(this)) {p = re3.exec(this);return new Date(p[3],p[1],p[2]);}return false;}/*** 检查是否有列表中的字符字符 ***/String.prototype.isInList = function(list) {var re = eval("/["+list+"]/");return re.test(this);}。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
JS的正则表达式实例1.校验字符串是否全由数字组成代码function isDigit(s){var patrn=/^[0-9]{1,20}$/;if (!patrn.exec(s))return falsereturn true}2.校验登录名:只能输入5-20个以字母开头、可带数字、“_”、“.”的字串代码function isRegisterUserName(s){var patrn=/^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$/;if (!patrn.exec(s))return falsereturn true}3.校验用户姓名:只能输入1-30个以字母开头的字串代码function isTrueName(s){var patrn=/^[a-zA-Z]{1,30}$/;if (!patrn.exec(s))return falsereturn true}4.校验密码:只能输入6-20个字母、数字、下划线代码function isPasswd(s){var patrn=/^(\w){6,20}$/;if (!patrn.exec(s))return falsereturn true}5.//校验普通电话、传真号码:可以“+”开头,除数字外,可含有“-”代码function isTel(s){//var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?(\d){1,12})+$/;var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/;if (!patrn.exec(s))return falsereturn true}6.校验手机号码:必须以数字开头,除数字外,可含有“-”代码function isMobil(s){var patrn=/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/;if (!patrn.exec(s))return falsereturn true}7.校验邮政编码代码function isPostalCode(s){//var patrn=/^[a-zA-Z0-9]{3,12}$/;var patrn=/^[a-zA-Z0-9 ]{3,12}$/;if (!patrn.exec(s))return falsereturn true}8.校验搜索关键字代码function isSearch(s){varpatrn=/^[^`~!@#$%^&*()+=|\\\][\]\{\}:;'\,.<>/?]{1}[^`~!@$%^&()+=|\\\] [\]\{\}:;'\,.<>?]{0,19}$/;if (!patrn.exec(s)) return falsereturn true}function isIP(s) //by zergling{var patrn=/^[0-9.]{1,20}$/;if (!patrn.exec(s)) return falsereturn true}9.正则表达式代码1. "^\\d+$" //非负整数(正整数 + 0)2. "^[0-9]*[1-9][0-9]*$" //正整数3. "^((-\\d+)|(0+))$" //非正整数(负整数 + 0)4. "^-[0-9]*[1-9][0-9]*$" //负整数5. "^-?\\d+$" //整数6. "^\\d+(\\.\\d+)?$" //非负浮点数(正浮点数 + 0)7."^(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[ 1-9][0-9]*))$"8. //正浮点数9. "^((-\\d+(\\.\\d+)?)|(0+(\\.0+)?))$" //非正浮点数(负浮点数 + 0)10."^(-(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9] *[1-9][0-9]*)))$"11. //负浮点数12. "^(-?\\d+)(\\.\\d+)?$" //浮点数13. "^[A-Za-z]+$" //由26个英文字母组成的字符串14. "^[A-Z]+$" //由26个英文字母的大写组成的字符串15. "^[a-z]+$" //由26个英文字母的小写组成的字符串16. "^[A-Za-z0-9]+$" //由数字和26个英文字母组成的字符串17. "^\\w+$" //由数字、26个英文字母或者下划线组成的字符串18. "^[\\w-]+(\\.[\\w-]+)*@[\\w-]+(\\.[\\w-]+)+$" //email地址19. "^[a-zA-z]+://(\\w+(-\\w+)*)(\\.(\\w+(-\\w+)*))*(\\?\\S*)?$"//url20. "^[A-Za-z0-9_]*$"10.正则表达式使用详解简介简单的说,正则表达式是一种可以用于模式匹配和替换的强有力的工具。
其作用如下:测试字符串的某个模式。
例如,可以对一个输入字符串进行测试,看在该字符串是否存在一个电话号码模式或一个信用卡号码模式。
这称为数据有效性验证。
替换文本。
可以在文档中使用一个正则表达式来标识特定文字,然后可以全部将其删除,或者替换为别的文字。
根据模式匹配从字符串中提取一个子字符串。
可以用来在文本或输入字段中查找特定文字。
基本语法在对正则表达式的功能和作用有了初步的了解之后,我们就来具体看一下正则表达式的语法格式。
正则表达式的形式一般如下:/love/ 其中位于“/”定界符之间的部分就是将要在目标对象中进行匹配的模式。
用户只要把希望查找匹配对象的模式内容放入“/”定界符之间即可。
为了能够使用户更加灵活的定制模式内容,正则表达式提供了专门的“元字符”。
所谓元字符就是指那些在正则表达式中具有特殊意义的专用字符,可以用来规定其前导字符(即位于元字符前面的字符)在目标对象中的出现模式。
较为常用的元字符包括:“+”,“*”,以及“?”。
“+”元字符规定其前导字符必须在目标对象中连续出现一次或多次。
“*”元字符规定其前导字符必须在目标对象中出现零次或连续多次。
“?”元字符规定其前导对象必须在目标对象中连续出现零次或一次。
下面,就让我们来看一下正则表达式元字符的具体应用。
/fo+/ 因为上述正则表达式中包含“+”元字符,表示可以与目标对象中的“fool”, “fo”, 或者“football”等在字母f后面连续出现一个或多个字母o的字符串相匹配。
/eg*/ 因为上述正则表达式中包含“*”元字符,表示可以与目标对象中的“easy”, “ego”, 或者“egg”等在字母e后面连续出现零个或多个字母g 的字符串相匹配。
/Wil?/ 因为上述正则表达式中包含“?”元字符,表示可以与目标对象中的“Win”, 或者“Wilson”,等在字母i后面连续出现零个或一个字母l的字符串相匹配。
有时候不知道要匹配多少字符。
为了能适应这种不确定性,正则表达式支持限定符的概念。
这些限定符可以指定正则表达式的一个给定组件必须要出现多少次才能满足匹配。
{n} n 是一个非负整数。
匹配确定的 n 次。
例如,'o{2}' 不能匹配 "Bob" 中的 'o',但是能匹配 "food" 中的两个 o。
{n,} n 是一个非负整数。
至少匹配 n 次。
例如,'o{2,}' 不能匹配 "Bob" 中的 'o',但能匹配 "foooood" 中的所有 o。
'o{1,}' 等价于 'o+'。
'o{0,}' 则等价于 'o*'。
{n,m} m 和 n 均为非负整数,其中n <= m。
最少匹配 n 次且最多匹配 m 次。
例如,"o{1,3}" 将匹配 "fooooood" 中的前三个 o。
'o{0,1}' 等价于 'o?'。
请注意在逗号和两个数之间不能有空格。
除了元字符之外,用户还可以精确指定模式在匹配对象中出现的频率。
例如,/jim {2,6}/ 上述正则表达式规定字符m可以在匹配对象中连续出现2-6次,因此,上述正则表达式可以同jimmy或jimmmmmy等字符串相匹配。
在对如何使用正则表达式有了初步了解之后,我们来看一下其它几个重要的元字符的使用方式。
只能输入数字:"^[0-9]*$"。
只能输入n位的数字:"^\d{n}$"。
只能输入至少n位的数字:"^\d{n,}$"。
只能输入m~n位的数字:。
"^\d{m,n}$"只能输入零和非零开头的数字:"^(0|[1-9][0-9]*)$"。
只能输入有两位小数的正实数:"^[0-9]+(.[0-9]{2})?$"。
只能输入有1~3位小数的正实数:"^[0-9]+(.[0-9]{1,3})?$"。
只能输入非零的正整数:"^\+?[1-9][0-9]*$"。
只能输入非零的负整数:"^\-[1-9][]0-9"*$。
只能输入长度为3的字符:"^.{3}$"。
只能输入由26个英文字母组成的字符串:"^[A-Za-z]+$"。
只能输入由26个大写英文字母组成的字符串:"^[A-Z]+$"。
只能输入由26个小写英文字母组成的字符串:"^[a-z]+$"。
只能输入由数字和26个英文字母组成的字符串:"^[A-Za-z0-9]+$"。
只能输入由数字、26个英文字母或者下划线组成的字符串:"^\w+$"。