js正则表达式函数(正则表达式 js)
js 不能为空的正则表达式怎么写?
答案:var reg = /\S/;
reg.test($("value").val());
正则表达式是对字符串(包括普通字符(例如,a 到 z 之间的字母)和特殊字符(称为“元字符”))操作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。
正则表达式是一种文本模式,该模式描述在搜索文本时要匹配的一个或多个字符串。
扩展资料:
正则表达式的特点是:
1. 灵活性、逻辑性和功能性非常强;
2. 可以迅速地用极简单的方式达到字符串的复杂控制。
3. 对于刚接触的人来说,比较晦涩难懂。
由于正则表达式主要应用对象是文本,因此它在各种文本编辑器场合都有应用,小到著名编辑器EditPlus,大到Microsoft Word、Visual Studio等大型编辑器,都可以使用正则表达式来处理文本内容。
参考资料:百度百科——正则表达式
JS正则表达式基础认知
? ? ? ? 正则表达式,又叫规则表达式,英文名Regular Expression,本质是操作字符串
? ? ? ? ?1、模式匹配? ? 表单验证
? ? ? ? ?2、文本检索? ? 搜索
? ? ? ? ?3、替换? ? ? ? 过滤
? ? ? ? ?简单,方便,性能高
? ? ? ? var reg=new RegExp('规则','模式')? 通过构造函数创造
? ? ? ? var reg=/规则/模式? ? ? ? ? ? ? ? 通过字面量创建
? ? ? ?i? 忽略大小写
? ? ? ?g? 全局
? ? ? ?m? 多行
? ? ? ?注:不分前后顺序
? ? ? str.match(正则)? 返回数组 没有返回 null
? ? ? str.search(正则)? 返回下标? 没有返回-1
? ? ? str.replace(正则,替换成谁)? 返回替换后的字符串
? ? ? str.replace(正则,function(s){
? ? ? ? ? ? ? ? ? ? ? ?s 符合正则条件的字符串
? ? ? ?})
? ? ? ?\d? 数字 /[0-9]/
? ? ? ?\s? 空格
? ? ? ?\w? /[0-9a-zA-Z_]/ 单词
? ? ? ?\D? 非数字? /[^0-9]/
? ? ? ?\S? 非空白
? ? ? ?\W? 非单词? /[^0-9a-zA-Z_]/
.(点)??? 代表任意
? ? ? ? ?\.? 代表.
? ? ? ? ?\\? 代表\
? ? ? ? ?\\\\? 代表\\
? ? ? ? ? \/? ? 代表/
? ? ? ? ? 只要有特殊意义的都要转译
? ? ? ? ? +? {1,m}? 若干个? 最少1个最多不限
? ? ? ? ? ? {0,1}? 可有可无
? ? ? ? ? *? {0,m}? 可以没有,多了不限
? ? ? ? ? {n}? 正好n个
? ? ? ? ?{n,m}? 最少n个 最多m个
? ? ? ? ?{n,}? 最少n个,最多不限
? ? ? ? ?{,m} × 没有这种写法
? ? ? ? ^? 行首
? ? ? ? ?注:如果^单独使用,代表字符串行首,配合m使用会识别段落
? ? ? ? $? 行尾
? ? ? ? [] 中括号
? ? ? ? ? ? ?1、[]里面的东西都是或的形式
? ? ? ? ? ? ?2、[]里面和放范围
? ? ? ? ? ? ?3、[^]? 不代表行首,代表除去里面的范围
? ? ? ? ? ? ?4、其他特殊符号代表本身
? ? ? ? ?1、test()? 一般配合^
? ? ? ? ? ? ? ?功能:用于检测是否于正则匹配。
? ? ? ? ? ? ? ?返回:布尔值,true匹配,false不匹配
? ? ? ? ? ? ? ?语法:reg.test(检测的内容)
? ? ? ? ? 2 exec()
? ? ? ? ? ? ? ?功能:用于检测是否于正则匹配。
? ? ? ? ? ? ? ?返回:数组, 不匹配返回null
? ? ? ? ? ? ? ?语法:reg.test(检测的内容)
? ? ? ? ? ? ? ?再做验证之前:验证分两种,一种强校验,一种弱校验
? ? ? ? ? ? (1)验证手机号? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? /1[23457]\d{9}/
? ? ? ? ? ? (2)验证座机号? ? ? 区号-座机号? ? ? ? ? ? /(0[1-9]\d-)?[1-9]\d{7}/
? ? ? ? ? ? (3)验证qq? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? /[1-9]\d{4,11}/
? ? ? ? ? ? (4)实现一个trim函数 去掉收尾空格? ? ? /^\s+|\s+$/g
? ? ? ? ? ? (5)中文? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? /[\u4e00-\u9fa5]/
? ? ? ? ? ? (6)验证年龄? ? ? ?18-100? ? ? ? ? ? ? ? ? ? ? ?/^1[89]|[2-9]\d|100$/
? ? ? ? ? ? (7)邮箱:? ? ?asdsad@163.com? ? ? ? ? ?/^\w{5,12}@[a-z0-9]{2,8}\.com$/
? ? ? ? ? ? (8)? 过滤html? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? /[^]+/g;
? ? ? ? 1、分组? ? ab+ abbbb? (ab)+
? ? ? ? 2、匹配子级
? ? ? ? ? ? ? 配合replace使用? str.replace(reg,function(s,a,b){
? ? ? ? ? ? ? ?s是 整体
? ? ? ? ? ? ? ?a是第一个括号的项
? ? ? ? ? ? ? ?b是第二个括号的项
? ? ? ? ? })
? ? ? ? 3、优选级? ^(1[89]|[2-9]\d|100)$
? ? ? ? 4、重复的子项
? ? ? ? ? ? ? abbb? ? ? ? ? /(a)(b)\2+/
今天先给大家总结到这儿,后续还会有补充
Js 中的 正则表达式?
1定义正则表达式
在js中定义正则表达式很简单,有两种方式,一种是通过构造函数,一种是通过//,也就是两个斜杠。
例如
代码如下:
var re =new RegExp("\\?(\\w{1,}=\\w{1,}){1,}\\w{1,}=\\w{1,}");
使用构造函数定义正则表达式,注意大小写,负责就会不起作用。由于构造函数的参数是一个字符串,也可以是两个斜杠的方式定义,遇到一些特殊字符就需要使用\进行转义
通过双斜杠的方式定义同样的正则表达式
代码如下:
var re =/\?(\w{1,}=\w{1,}){1,}\w{1,}=\w{1,}/;
代码如下:
var re =new RegExp( /^\?(\w{1,}=\w{1,}){1,}\w{1,}=\w{1,}/);
可以和构造函数达到同样的效果,但仔细分析,发现,通过构造函数需要更多的转义字符\
2关于验证的三个正则表达式方法
使用正则表达式的主要有字符串的方法match,正则表达式的方法exec,test
正则表达式方法test测试给定的字符串是否满足正则表达式,返回值是bool类型的,只有真和假,如果只是单纯的判断,不需要其他的处理,可以使用尤其是验证时。
代码如下:
function test(){
var text="index.aspx?test=1ww=2www=3"; //
var re =/\?(\w{1,}=\w{1,}){1,}\w{1,}=\w{1,}/;
// var re =new RegExp("\\?(\\w{1,}=\\w{1,}){1,}\\w{1,}=\\w{1,}");
var result= re.test(text);
if(result)
{
alert("ok");
}else
{
alert("err");
}
}
正则表达式方法exec测试给定的字符串是否满足正则表达式,返回匹配到的字符串,如果没有匹配的则返回null,和test基本一致,如果需要获取匹配的各个子字符串,可以使用下标的方式,把上边的test的例子可以改写如下
代码如下:
function test(){
var text="index.aspx?test=1ww=2www=3";
var re = /\?(\w{1,}=\w{1,}){1,}\w{1,}=\w{1,}/;
// var re =new RegExp( "\\?(\\w{1,}=\\w{1,}){1,}\\w{1,}=\\w{1,}");
var result= re.exec(text);
if(result)
{
alert("ok");
alert(result); // 是?test=1ww=2www=3,ww=2
alert(result[0]+",0");//是?test=1ww=2www=3
alert(result[1]+",1");//是ww=2
}else
{
alert("err");
}
}
match其实是字符串的方法,但参数确是一个正则表达式,把上边的例子改写后,如下
代码如下:
function test(){
var text="index.aspx?test=1ww=234"; //
var re = /\?(\w{1,}=\w{1,}){1,}\w{1,}=\w{1,}/;
// var re2 = "(\\w{1,}=\\w{1,}){1,}\\w{1,}=\\w{1,}"
var result= text.match(re);
if(result)
{
alert(result);//?test=1ww=234,test=1
alert(result[0]+",0");//?test=1ww=234
alert(result[1]+",1");//test=1
}else
{
alert("err");
}
}
其实字符串类还有多个函数可以传递正则表达式,split,search,replace等但这些方法已经不适合验证了。
代码如下:
function test(){
var text="index.aspx?test=1ww=234"; //
var re = /\?(\w{1,}=\w{1,}){1,}\w{1,}=\w{1,}/;
// var re2 = "(\\w{1,}=\\w{1,}){1,}\\w{1,}=\\w{1,}"
var result= text.split(re);
alert(result);
alert(result[0]+",0");
alert(result[1]+",1");
}
3正则表达式式的转义字符
在正则表达式中会经常出现转义字符,例如问号?在正则表达式中有特殊的含义,如果需要匹配问号?就需要转义,使用转义字符反斜杠\
如下两个都是匹配问号开头的一段字符串
代码如下:
function test(){
var text="?test=1ww=2www=3";
var re = /^\?(\w{1,}=\w{1,}){1,}\w{1,}=\w{1,}/;// \?表示配置问号?
// var re =new RegExp( "^\\?(\\w{1,}=\\w{1,}){1,}\\w{1,}=\\w{1,}");// \\?表示配置问号?
var result= re.exec(text);
if(result)
{
alert("ok");
alert(result);
alert(result[0]+",0");
alert(result[1]+",1");
}else
{
alert("err");
}
}
【总结】js正则表达式及验证函数
用户名或昵称 :?^[\u4e00-\u9fa5A-Za-z0-9-_]*$——只能中英文,数字,下划线,减号
用户密码: ^[a-zA-Z]\w{5,17}$ 正确格式为——以字母开头,长度在6-18之间,只能包含字符、数字和下划线。
汉字 :^[\u4e00-\u9fa5],{0,}$
Email地址 :^\w+[-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$
? ? ? ? ? ? ? ? ? ? ?^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$
IP地址 :^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])(\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])){3}$
日期 格式是否为YYYY-MM-DD:^\d{4}-(0?[1-9]|1[0-2])-(0?[1-9]|[1-2]\d|3[0-1])$/;
时间 格式是否为hh:mm:ss:^([0-1]\\d|2[0-3]):[0-5]\\d:[0-5]\\d$
InternetURL :^http://([\w-]+\.)+[\w-]+(/[\w-./?%=]*)?$ ;^[a-zA-z]+://(w+(-w+)*)(.(w+(-w+)*))*(?S*)?$
? ? ? ? ? ? ? ? ? ? ? ? ? ? ^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-_~`@[\]\':+!]*([^\"\"])*$
电话号码 :^(\(\d{3,4}\)|\d{3,4}-)?\d{7,8}$——正确格式为:XXXX-XXXXXXX,XXXX-XXXXXXXX,XXX-XXXXXXX,XXX-XXXXXXXX,XXXXXXX,XXXXXXXX。
? ??????????????????????^((\(\d{2,3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$
手机号码 :^0?(13[0-9]|15[012356789]|18[0236789]|14[57])[0-9]{8}$:打长途时一般要在手机号码前加0。
身份证号 (15位或18位数字):^\d{15}(\d{2}[A-Za-z0-9])?$
QQ号码 : /^[1-9]\d{4,8}$/
验证是否含有 ^%',;=?$\" 等字符:[^%',;=?$\x22]+
验证一年的12个月:^(0?[1-9]|1[0-2])$ 正确格式为:“01”-“09”和“1”“12”
验证一个月的31天:^((0?[1-9])|((1|2)[0-9])|30|31)$ 正确格式为:01、09和1、31。
验证数字:^[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]*$
验证非负整数(正整数 + 0) ^\d+$
验证非正整数(负整数 + 0) ^((-\d+)|(0+))$
验证长度为3的字符:^.{3}$
验证由26个英文字母组成的字符串:^[A-Za-z]+$
验证由26个大写英文字母组成的字符串:^[A-Z]+$
验证由26个小写英文字母组成的字符串:^[a-z]+$
验证由数字和26个英文字母组成的字符串:^[A-Za-z0-9]+$
验证由数字、26个英文字母或者下划线组成的字符串:^\w+$
整数:^-?\d+$
非负浮点数(正浮点数 + 0):^\d+(\.\d+)?$
正浮点数: ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$
非正浮点数(负浮点数 + 0):^((-\d+(\.\d+)?)|(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+)?$
双精度:^[-\+]?\d+(\.\d+)?$
//判断输入的字符是否为中文
function IsChinese(){
????var str = document.getElementById('str').value.trim();
? ? if(str.length!=0){
????????reg=/^[\u0391-\uFFE5]+$/;
????????if(!reg.test(str)){
????????????alert("对不起,您输入的字符串类型格式不正确!");
????????}
????}
}
//判断输入的数字不大于某个特定的数字
function MaxValue(){
????var val = document.getElementById('str').value.trim();
????if(str.length!=0){
????????reg=/^[-+]?\d*$/;
????????if(!reg.test(str)){//判断是否为数字类型
????????????if(valparseInt('123')){//“123”为自己设定的最大值
????????????????alert('对不起,您输入的数字超出范围');
? ? ? ? ? ? }
????????}
????}
}
//为上面提供各个JS验证方法提供.trim()属性
String.prototype.trim=function(){
????return this.replace(/(^\s*)|(\s*$)/g, "");
}
var?patterms?=?newObject();
//验证IP
patterms.ip?=?/^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])(\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])){3}$/;
//验证EMAIL
patterms.email?=?/^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/;
//验证函数
functionverify(str,pat){
????var thePat?= patterms[pat];
????if(thePat.test(str)){
????????return?true;
????}else{
????????return?false;
????}
}
//测试alert(verify("asidycom@163.com","email")+","+verify("192.168.1.1","ip")+","+verify("192.168","ip"));
本文摘自: js正则表达式验证大全
JS正则表达式详解
在H5开发中,正则表达式有很多地方都用得到,固整理了正则表达式的基本规则,和在JS中如何使用正则表达式,做了简单的介绍。
当 RegExpObject 是一个全局正则表达式时,exec() 的行为就稍微复杂一些。它会在RegExpObject的 lastIndex属性指定的字符处开始检索字符串 string。当 exec()找到了与表达式相匹配的文本时,在匹配后,它将把 RegExpObject 的 lastIndex 属性设置为匹配文本的最后一个字符的下一个位置。这就是说,您可以通过反复调用 exec() 方法来遍历字符串中的所有匹配文本。当exec() 再也找不到匹配的文本时,它将返回null,并把lastIndex 属性重置为 0。
eg:全局正则表达式
本篇主要针对正则基础的阐述,如果希望在熟练地应用到开发中还需要多多练习。