JS 小驼峰与下划线命名法互转
作者:互联网
原理
小驼峰命名法:camelCase
下划线命名法:snake_case
通过递归的办法,遍历出对象里的所有属性名,然后正则替换
代码
下划线 → 小驼峰
// 将 sanke 命名转 camel 命名
function snake2camel (data) {
if (typeof data !== 'object' || !data) { return data }
if (Array.isArray(data)) { return data.map(item => snake2camel(item)) }
const newData = {}
for (const key in data) {
const newKey = key.replace(/_([a-z])/g, (p, m) => m.toUpperCase())
newData[newKey] = snake2camel(data[key])
}
return newData
}
小驼峰 → 下划线
// 将 camel 命名转 sanke 命名
function camel2snake (data) {
if (typeof data !== 'object' || !data) { return data }
if (Array.isArray(data)) { return data.map(item => camel2snake(item)) }
const newData = {}
for (const key in data) {
const newKey = key.replace(/([A-Z])/g, (p, m) => `_${m.toLowerCase()}`)
newData[newKey] = camel2snake(data[key])
}
return newData
}
标签:const,下划线,JS,命名,key,互转,return,data,newData 来源: https://www.cnblogs.com/conne/p/15855406.html