js正则表达式replace中参数为$1、$2、...、$99、函数等用法以及常用的正则表达式

语法:

string.replace(regexp, replacement)

参数:

regexp:必需。要搜索的值或正则表达式。

replacement:必需。指定替换文本或生成替换文本的函数。

返回值:已替换指定值的新字符串。

w3school:JavaScript String replace() 方法

一、常规使用

将aaa替换为111:

var str = "aaa,bbb,ccc";
str.replace('aaa', "111");//输出'111,bbb,ccc'

将连续的字母替换为111:

var str = "aaaaaaa,bbbbbb,ccc";
str.replace(/\w+/g, "111");//输出'111,111,111'

 将所有字母全部替换为1:

var str = "aaa,bbb,ccc";
str.replace(/\w/g, "1");//输出'111,111,111'

二、$1、$2、...、$99

var str = "aaa,bbb,ccc";
str.replace(/(\w+),(\w+),(\w+)/, "$3,$2,$1");//输出'ccc,bbb,aaa'
  • $1代表第一个(\w+)匹配到的内容,即aaa
  • $2代表第一个(\w+)匹配到的内容,即bbb
  • $3代表第一个(\w+)匹配到的内容,即ccc
var str = "aaa、bbb、ccc";
str.replace(/(\w)+、(\w)+、(\w)+/, "$3$2$1");//输出'cba'
  • $1代表第一个(\w)匹配到的内容,即a
  • $2代表第一个(\w)匹配到的内容,即b
  • $3代表第一个(\w)匹配到的内容,即c

结论:$1、$2、...、$99 表示正则表达式中的括号匹配项的结果。

扫描二维码关注公众号,回复: 16259745 查看本文章

三、函数

//输出'hello,world'
var str = "Hello,World";
str.replace(/[A-Z]/g, function(val){
    return val.toLowerCase()
});

//输出'HELLO,WORLD'
var str = "Hello,World";
str.replace(/[a-z]/g, function(val){
    return val.toUpperCase()
});

//输出'000,000,111'
var str = "aaaaaaa,bbbbbb,ccc";
str.replace(/\w+/g, function(val){
    return val === 'ccc' ? '111':'000'
});

一个经典的例子——模板字符匹配: 

var data = {
    title:'标题',
    subTitle: '副标题',
    content:'内容'
}
var str='这是一段内容,标题是{
   
   {title}},副标题是{
   
   {subTitle}},内容是{
   
   {content}}'

str.replace(/\{\{(.*?)\}\}/g, function(val,key){
    return data[key]
});

输出:这是一段内容,标题是标题,副标题是副标题,内容是内容

这里函数的第一个参数是匹配的内容,第二个参数是括号匹配的结果

四、其他常用正则表达式

邮箱格式:^[a-z0-9A-Z]+[- | a-z0-9A-Z . _]+@([a-z0-9A-Z]+(-[a-z0-9A-Z]+)?\\.)+[a-z]{2,}$

正整数:^[1-9]([0-9])*$

身份证号 ^[1-9]\\d{5}(18|19|([23]\\d))\\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\\d{3}[0-9Xx]$
ip地址 ^[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}$
数字或英文字母 ^([0-9a-zA-Z]+)$
手机号码 ^((13[0-9])|(14[5,7])|(15[0-3,5-9])|(17[0,3,5-8])|(18[0-9])|166|198|199|(147))\\d{8}$
日期时间格式YYYY-MM-DD HH:mm:ss ^(\\d{4}-\\d{2}-\\d{2} \\d{2}:\\d{2}:\\d{2})$
日期格式YYYY-MM-DD ^(\\d{4}-\\d{2}-\\d{2})$
合法url

(https?|ftp|file)://[-A-Za-z0-9+&@#/%?=~_|!:,.;]+[-A-Za-z0-9+&@#/%=~_|]

最多三位小数 ^(?:[1-9]\\d*|0)(?:\\.\\d{1,3})?$
大于等于0且最多三位小数 ^(?!0+(?:\\.0+)?$)(?:[1-9]\\d*|0)(?:\\.\\d{1,3})?$
最多两位小数 ^(?:[1-9]\\d*|0)(?:\\.\\d{1,2})?$
大于等于0且最多两位小数 ^(?!0+(?:\\.0+)?$)(?:[1-9]\\d*|0)(?:\\.\\d{1,2})?$
至少两个字符,中文或英文 ^([a-zA-Z\\u4E00-\\u9FA5]+)$
3-15个字符,仅限数字、字母、斜杠、横杠、点 ^[-/0-9A-Za-z.]{3,15}$

猜你喜欢

转载自blog.csdn.net/sxww_zyt/article/details/130258920