假设需要进行替换的字符串为str1,那么:
str1.replace(/\\/g,'\\\\')
完整的例子:
var str1 = 'a\\b\\c'
var str2 = str1.replace(/\\/g,'\\\\')
console.log(str1)
console.log(str2)
扩展资料:
正则表达式:
语法:/正则表达式主体/修饰符(可选)
replace() 方法使用正则表达式
例子:
使用正则表达式且不区分大小写将字符串中的 Microsoft 替换为 Runoob :
var str = document.getElementById("demo").innerHTML
var txt = str.replace(/microsoft/i,"Runoob")
修饰符:
i:执行对大小写不敏感的匹配。
g:执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。
m:执行多行匹配。
正则表达式的前后使用/是语法规定,犹如字符串的前后使用引号一样。你这个地方加不加g无所谓的,g表示多次匹配,只有在需要对每个匹配的项目进行处理(例如替换)时才有特殊意义。
第一个因为没有^和$,所以只有要数字和-就对,第二个有这两个符号,^表示开始,$表示结束,整体的意思就是必须完整匹配,不得有其它内容。例如ABC028-88888就可以匹配第一种方式,但是在第二种就会失败。
还有问题吗?
RegExp()的第二个参数主要支持g,i,m这3个修饰性字符
字符g,用来指定全局匹配
字符 i ,是用来指定大小写为等同;
字符 m 是多行一词的缩写,设置匹配模式能够在多行字符串中执行操作
var a = "javasssss"
var s = new RegExp("a","gi")
alert(a.match(s))
返回值为a,a
var a = "javasssss sssswww aaaaa"
var s = new RegExp("\\b\\w","gi")
alert(a.match(s))
返回值为j,s,a
\\b\\w是一个匹配模式,其中反斜杠表示转义序列,而双斜杠表示的是斜杠的意思,\b表示边界的意思\w表示的任意的ASCii码,指的就是每一个单词的首字母;
var a = "javasssss sssswww aaaaa"
var r=new RegExp("\\x61")
var s=a.match(r)
alert(s)
x61表示的是a的十六进制的ascii码,除了十六进制以外,还可以直接使用八进制数值来匹配例如;
var a = "javasssss sssswww aaaaa"
var r=new RegExp("\\141")
var s=a.match(r)
alert(s)
js中的特殊字符
\o表示空字符
\t表示制表位
\n表示换行符
\v表示垂直制表符
\f表示换页符
\r表示回车符
\a表示alert字符
\e表示escape字符
\b表示回退字符
\cX表示控制自负^x
对于这些特殊的字符,如果在RegExp构造函数中使用,必须使用双斜杠表示专业。
定义简单的字符类
var a = "javasssss sssswww aaaaa"
var r=new RegExp("[abcsw]","gi")
var s=a.match(r)
alert(s)
返回值为
查找字符串中是否有字符类中的字母
定义反义字符类
var a = "aba abd abg abe"
var r=new RegExp("ab[^abc]","gi")
var s=a.match(r)
alert(s)
返回值为
第三个字符表示除了a,b,c以外的字符都可以
var r= new RegExp("[^012345679]","gi")
匹配除了数字以外任意的字符。反义字符类比简单字符类更加强大和实用
如果任意双字节的汉字,你可以这样设计
var r=new RegExp("\\u0000-\\u00ff","gi");
预定义字符类