欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS封裝轉(zhuǎn)換前后端接口數(shù)據(jù)格式工具函數(shù)下劃線<=>大寫

 更新時間:2023年03月31日 09:42:25   作者:我擱這敲代碼呢  
這篇文章主要為大家介紹了JS優(yōu)雅封裝轉(zhuǎn)換前后端接口數(shù)據(jù)格式工具函數(shù)下劃線<=>大寫實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

一、前言

這段時間接近年底,公司的業(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ù)式編程的影響示例解析

    這篇文章主要為大家介紹了JavaScript數(shù)據(jù)類型對函數(shù)式編程的影響示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • JS疑惑的數(shù)據(jù)類型及類型判斷方法詳解

    JS疑惑的數(shù)據(jù)類型及類型判斷方法詳解

    這篇文章主要為大家介紹了JS中疑惑的數(shù)據(jù)類型及類型判斷方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • 微信小程序 簡單DEMO布局,邏輯,樣式的練習(xí)

    微信小程序 簡單DEMO布局,邏輯,樣式的練習(xí)

    這篇文章主要介紹了微信小程序 簡單DEMO布局,邏輯,樣式的練習(xí)的相關(guān)資料,這里寫一個簡單實例練習(xí)小程序的布局,并附實例代碼和實現(xiàn)效果圖,需要的朋友可以參考下
    2016-11-11
  • 一文詳解js基本類型與引用類型的區(qū)別

    一文詳解js基本類型與引用類型的區(qū)別

    這篇文章主要為大家介紹了js基本類型與引用類型的區(qū)別詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • js中的函數(shù)嵌套和閉包詳情

    js中的函數(shù)嵌套和閉包詳情

    這篇文章主要介紹了js中的函數(shù)嵌套和閉包,在聊閉包這個問題之前,先了解一下變量的定義域,在js中,變量定義域有全局作用域和局部作用域之說,文章主要介紹函數(shù)的作用域,需要的朋友可以參考一下
    2021-11-11
  • JS實現(xiàn)密碼箱小程序幫你記住各種密碼

    JS實現(xiàn)密碼箱小程序幫你記住各種密碼

    這篇文章主要介紹了JS實現(xiàn)密碼箱小程序再也不用記各種密碼,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • ResizeObserver?API使用示例詳解

    ResizeObserver?API使用示例詳解

    這篇文章主要為大家介紹了ResizeObserver?API使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • js封裝一個websocket實現(xiàn)及使用詳解

    js封裝一個websocket實現(xiàn)及使用詳解

    這篇文章主要為大家介紹了js封裝一個websocket實現(xiàn)示例及使用方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • 微信小程序 兩種為對象屬性賦值的方式詳解

    微信小程序 兩種為對象屬性賦值的方式詳解

    這篇文章主要介紹了微信小程序 兩種為對象屬性賦值的方式詳解的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • tree?shaking對打包體積優(yōu)化及作用

    tree?shaking對打包體積優(yōu)化及作用

    這篇文章主要為大家介紹了tree?shaking對打包體積優(yōu)化及作用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07

最新評論