JS封裝轉(zhuǎn)換前后端接口數(shù)據(jù)格式工具函數(shù)下劃線<=>大寫
一、前言
這段時(shí)間接近年底,公司的業(yè)務(wù)也不是很繁忙,有些閑暇的時(shí)間,就模仿ruoyi寫一個(gè)后臺(tái)系統(tǒng),技術(shù)棧前端是react18,后端為koa2;
在一個(gè)接口返回?cái)?shù)據(jù)的過程中,遇到一個(gè)問題,就是后端數(shù)據(jù)保存到數(shù)據(jù)庫中的命名標(biāo)準(zhǔn)是下劃線,而前端的這邊的命名標(biāo)準(zhǔn)是駝峰命名,所以如果直接將從數(shù)據(jù)庫的數(shù)據(jù)返回給前端,便非常不優(yōu)雅,網(wǎng)上想直接找工具包,也沒找到合適的,故而自己手寫了一個(gè),如果有同樣需求的小伙伴們,可以直接拿去用。
二、思路
- 一般后端返回給前端的數(shù)據(jù)幾乎都是數(shù)組或者對象兩種格式,所以我們封裝的函數(shù)只需要考慮這兩種情況;
- 首先,我們這個(gè)函數(shù)需要滿足后端返回給前端的數(shù)據(jù)(下劃線轉(zhuǎn)駝峰),前端傳數(shù)據(jù)給后端(駝峰轉(zhuǎn)下劃線)兩種情況;
- 函數(shù)接收兩個(gè)值,第一個(gè)data(數(shù)組或?qū)ο髷?shù)據(jù)源),第二個(gè)type(判斷要哪種轉(zhuǎn)換模式:hump為下劃線轉(zhuǎn)駝峰,'line'為駝峰轉(zhuǎn)下劃線);
- 首先,對傳入的data進(jìn)行判斷,如果是對象則轉(zhuǎn)換為數(shù)組,如果是數(shù)組則直接放行,然后深拷貝對象,防止意想不到的堆污染;
- 因?yàn)閿?shù)據(jù)的層數(shù)是不確定的,所以需要使用遞歸,對對象的value進(jìn)行判斷,如果是對象則遞歸;
- 遍歷data,對每個(gè)對象用forin進(jìn)行遍歷,然后根據(jù)type進(jìn)行相應(yīng)的處理,下劃線還要考慮到如果是最前面的下劃線,則直接刪除即可;
- 對象的改變是先保存原來的value,然后改變key后,將原來的key:value用delete刪除掉,然后再重新賦值(如果有更好的方法,可以和我說,我個(gè)人也感覺這種方法不是很優(yōu)雅);
- 最后,因?yàn)樯厦娌僮鳛榱朔奖悴僮?,?huì)將對象轉(zhuǎn)化為數(shù)組格式,操作完后,需要將原先是對象的重新轉(zhuǎn)化為對象,再返回回去,這樣不是更改原格式;
三、代碼
/** 返回?cái)?shù)據(jù)下劃線駝峰互轉(zhuǎn)函數(shù)封裝
* @param {data} 'obj或ary'
* @param {type} 'hump' 為下劃線轉(zhuǎn)駝峰,'line' 為駝峰轉(zhuǎn)下劃線
* @return {Array||Object}
*/
export const formatHumpLineTransfer = (data, type = 'hump') => {
// 判斷傳入的值是對象還是數(shù)組
const newData =
Object.prototype.toString.call(data) === '[object Object]'
? [JSON.parse(JSON.stringify(data))]
: JSON.parse(JSON.stringify(data))
?
function toggleFn(list) {
list.forEach((item) => {
for (const key in item) {
// 如果值為對象
if (Object.prototype.toString.call(item[key]) === '[object Object]') {
toggleFn([item[key]])
}
// 如果值為數(shù)組
else if (Object.prototype.toString.call(item[key]) === '[object Array]') {
toggleFn(item[key])
}
// 下劃線 轉(zhuǎn) 駝峰
else if (type === 'hump') {
const keyArr = key.split('_')
let str = ''
if (keyArr.length > 1) {
keyArr.forEach((item, index) => {
if (item) {
if (index) {
const arr = item.split('')
arr[0] = arr[0].toUpperCase()
str += arr.join('')
} else {
str += item
}
}
if (!item) {
keyArr.splice(0, 1)
}
})
const newValue = item[key]
delete item[key]
item[str] = newValue
}
}
// 駝峰 轉(zhuǎn) 下劃線
else if (type === 'line') {
const regexp = /^[A-Z]+$/
const newKey = key.split('')
const newValue = item[key]
newKey.forEach((item2, index2) => {
if (regexp.test(item2)) {
newKey[index2] = '_' + item2.toLowerCase()
}
})
delete item[key]
item[newKey.join('')] = newValue
}
}
})
}
toggleFn(newData)
// 因?yàn)樯厦娌僮鳛榱朔奖悴僮鳎瑫?huì)將對象轉(zhuǎn)化為數(shù)組格式,操作完后,需要將原先是對象的重新轉(zhuǎn)化為對象
if (Object.prototype.toString.call(data) === '[object Object]') {
let obj = null
newData.forEach((item) => (obj = item))
return obj
} else {
return newData
}
}
四、效果
轉(zhuǎn)換前:

轉(zhuǎn)換后:

結(jié)語
希望上面的能夠幫助遇到相同問題的小伙伴們,更多關(guān)于JS封裝轉(zhuǎn)換前后端接口數(shù)據(jù)格式的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
微信小程序 監(jiān)聽手勢滑動(dòng)切換頁面實(shí)例詳解
這篇文章主要介紹了微信小程序 監(jiān)聽手勢滑動(dòng)切換頁面實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-06-06

