JS封裝轉(zhuǎn)換前后端接口數(shù)據(jù)格式工具函數(shù)下劃線<=>大寫
一、前言
這段時間接近年底,公司的業(yè)務(wù)也不是很繁忙,有些閑暇的時間,就模仿ruoyi寫一個后臺系統(tǒng),技術(shù)棧前端是react18,后端為koa2;
在一個接口返回數(shù)據(jù)的過程中,遇到一個問題,就是后端數(shù)據(jù)保存到數(shù)據(jù)庫中的命名標準是下劃線,而前端的這邊的命名標準是駝峰命名,所以如果直接將從數(shù)據(jù)庫的數(shù)據(jù)返回給前端,便非常不優(yōu)雅,網(wǎng)上想直接找工具包,也沒找到合適的,故而自己手寫了一個,如果有同樣需求的小伙伴們,可以直接拿去用。
二、思路
- 一般后端返回給前端的數(shù)據(jù)幾乎都是數(shù)組或者對象兩種格式,所以我們封裝的函數(shù)只需要考慮這兩種情況;
- 首先,我們這個函數(shù)需要滿足后端返回給前端的數(shù)據(jù)(下劃線轉(zhuǎn)駝峰),前端傳數(shù)據(jù)給后端(駝峰轉(zhuǎn)下劃線)兩種情況;
- 函數(shù)接收兩個值,第一個data(數(shù)組或?qū)ο髷?shù)據(jù)源),第二個type(判斷要哪種轉(zhuǎn)換模式:hump為下劃線轉(zhuǎn)駝峰,'line'為駝峰轉(zhuǎn)下劃線);
- 首先,對傳入的data進行判斷,如果是對象則轉(zhuǎn)換為數(shù)組,如果是數(shù)組則直接放行,然后深拷貝對象,防止意想不到的堆污染;
- 因為數(shù)據(jù)的層數(shù)是不確定的,所以需要使用遞歸,對對象的value進行判斷,如果是對象則遞歸;
- 遍歷data,對每個對象用forin進行遍歷,然后根據(jù)type進行相應(yīng)的處理,下劃線還要考慮到如果是最前面的下劃線,則直接刪除即可;
- 對象的改變是先保存原來的value,然后改變key后,將原來的key:value用delete刪除掉,然后再重新賦值(如果有更好的方法,可以和我說,我個人也感覺這種方法不是很優(yōu)雅);
- 最后,因為上面操作為了方便操作,會將對象轉(zhuǎn)化為數(shù)組格式,操作完后,需要將原先是對象的重新轉(zhuǎn)化為對象,再返回回去,這樣不是更改原格式;
三、代碼
/** 返回數(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) // 因為上面操作為了方便操作,會將對象轉(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)文章
JavaScript數(shù)據(jù)類型對函數(shù)式編程的影響示例解析
這篇文章主要為大家介紹了JavaScript數(shù)據(jù)類型對函數(shù)式編程的影響示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-02-02