中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

js中如何完美的解析數據

發布時間:2020-09-11 09:13:33 來源:腳本之家 閱讀:147 作者:laozhang 欄目:web開發

自從有了前后端分離,一些后端小伙伴給出的數據結構也來越混亂了。以為分離減輕了他們的負擔接口的質量會非常高但是人的惰性卻體現的很“完美”。

由于js是若類型的語言,所以在使用數據的時候經常會出現這個幾個錯誤

TypeError: Cannot read property 'xxx' of undefined
TypeError: Cannot read property 'xxx' of null
TypeError: xxx.map is not a function

而這些異常很難發現,及時發上線了都不一定能發現。因為這些問題都是由于數據異常導致的。如果優雅的解決或者說避免這些問題影響到用戶體驗呢?

// 第一種做法肯定是這樣的
if(a){
  return a.name || '你沒名字'
}
// 這種做法處理簡單的還能湊合用,但是如果你遇到這樣的呢 user.country.area.city.name,難道要這樣寫
if(user && user.country && user.country.area && user.country.area.city){
  return user.country.area.city.name || '你沒名字'
}
// 這是多么痛苦的一件事情 @后端兄弟

// 第二種,感謝es6
let {country={area:{city:{name:'你沒名字'}}}} = user;
這個感覺也不是很好的解決方案

// 第三種,利用reduce構建一個解析函數
function getValue(obj,key){
  return key.split('.').reduce(function(o,k){
    // o,當前對象
    // key,數組下一個元素
    if((typeof o === 'undefined' || o === null)){
      return k.indexOf('[array]') !== -1?[]:o
    }else{
      return k.indexOf('[array]') !== -1?(o[k.replace('[array]','')]||[]):o[k]
    }
  },obj)
}

let user1;

let user2 = {
 
}

let user3 = {
 country:{
  area:{
   city:{
    name:'12312'
   }
  }
 }
}
let user4 = {
 country:[
  {
   city:{
    name:'12312'
   }
  }
 ]
}

let user5 = {
 country:{
  city:[1,2,3]
 }
}

console.log(getValue(user1,'country.area.city.name'))

console.log(getValue(user2,'country.area.city.name'))

console.log(getValue(user3,'country.area.city.name'))

console.log(getValue(user5,'country.city[array]'))
console.log(getValue(user5,'country.city[array].1'))
console.log(getValue(user5,'country.city[array].10'))
console.log(getValue(user5,'country.city[array].1.name'))
console.log(getValue(user5,'country.city[array].persion[array]'))

// 輸出結果
undefined
undefined
"12312"
[1, 2, 3]
2
undefined
undefined
[]

代碼測試:https://jsbin.com/zoberem/edit?js,console

最后關于前端異常上報,這是一個很大的研究方向,市面上也有一些解決方案,但是真正推廣的我目前沒發現。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

惠东县| 天水市| 阜康市| 丰镇市| 庆安县| 天祝| 修武县| 万州区| 沭阳县| 内丘县| 扎囊县| 柏乡县| 桐城市| 罗平县| 康保县| 密山市| 新乡市| 年辖:市辖区| 加查县| 彩票| 罗城| 武城县| 仪陇县| 扶绥县| 碌曲县| 琼结县| 芦山县| 顺昌县| 镇赉县| 苏尼特左旗| 宝山区| 新巴尔虎右旗| 惠州市| 张家港市| 合阳县| 沈丘县| 金湖县| 遵义市| 家居| 洛川县| 潞城市|