驼峰命名与下划线命名的转换方法
驼峰命名转下划线命名
// 驼峰命名转下划线命名
function toUnderLine(str){
let nstr = str.replace(/[A-Z]/g,function($0){//函数里只有一个参数时表示与 regexp 中的表达式相匹配的文本。有多个参数时表示与 regexp 中的子表达式相匹配的文本
console.log($0);//Y C 个人的理解就是第一个参数会返回正则表达式//里匹配到的所有文本
return "_"+$0.toLocaleLowerCase();
});
//防止有开头大驼峰
if(nstr.slice(0,1) == "_"){
nstr = nstr.slice(1)
}
return nstr;
}
console.log(toUnderLine("YxjComCn"));//yxj_com_cn
下划线命名转驼峰命名
// 下划线命名转驼峰命名 name_yxj_com
function toUpperCase(str){
// 匹配一个或多个下划线+ 后一个不是以下划线开头的字符
let nstr = str.replace(/(?:_)+([^_])/g,function($0,$1){
// console.log($0);//_n _y _c
console.log($1);//n y c
return $1.toUpperCase();
});
nstr = nstr.replace(nstr[0],nstr[0].toLowerCase());
return nstr;
}
console.log(toUpperCase("__name_yxj_com"));//nameYxjCom
总结
-
JavaScript replace() 方法配合正则表达式使用时可以发挥出强大的威力
-
replace() 方法有两个参数
参数 | 描述 |
---|---|
regexp/substr | 必需。规定子字符串或要替换的模式的 RegExp 对象。请注意,如果该值是一个字符串,则将它作为要检索的直接量文本模式,而不是首先被转换为 RegExp 对象。 |
replacement | 必需。一个字符串值。规定了替换文本或生成替换文本的函数。 |
- replacement是一个函数时他的参数具有特殊的意义
字符 | 替换文本 |
---|---|
$1、$2、…、$99 | 与 regexp 中的第 1 到第 99 个子表达式相匹配的文本。 |
$& | 与 regexp 相匹配的子串。 |
$` | 位于匹配子串左侧的文本。 |
$’ | 位于匹配子串右侧的文本。 |
$$ | 直接量符号。 |
ECMAScript v3 规定,replace() 方法的参数 replacement 可以是函数而不是字符串。在这种情况下,每个匹配都调用该函数,它返回的字符串将作为替换文本使用。该函数的第一个参数是匹配模式的字符串。接下来的参数是与模式中的子表达式匹配的字符串,可以有 0 个或多个这样的参数。接下来的参数是一个整数,声明了匹配在 stringObject 中出现的位置。最后一个参数是 stringObject 本身。
- 以上内容参考自 W3school