javascript - 聲明數組添加值會生成類型為undefine的值
問題描述
JS:用對象可以取得成功的值,用數組,就會出現有類型為undefined的值
var bodydata = $('body').data(); // console.log(bodydata);bodyDatas = {};/*使用了個全局變量bodyDatas*/_.forIn(bodydata,function(value,key){ if(typeof value == 'string'){value = parseLodash(n); } if(value[0] == '200'){var keyarray = key.split(’_’);var key0 = keyarray[0];var key1 = keyarray[1];var key2 = keyarray[2];_.forIn(_.keys(value[2]), function(v,k) { if (!bodyDatas[key0]) {bodyDatas[key0] = {}; } if (!bodyDatas[key0][key1]) {bodyDatas[key0][key1] = {}; } if (!bodyDatas[key0][key1][key2]) {bodyDatas[key0][key1][key2] = {}; } if (!bodyDatas[key0][key1][key2][v]) {bodyDatas[key0][key1][key2][v] = value[2][v]; }}); }else{console.log('取到數據頭部:'+n[0]); }})
以上可以獲取到正確的結果。
var bodydata = $('body').data(); bodyDatas = new Array();/*使用了個全局變量bodyDatas*/_.forIn(bodydata,function(value,key){ if(typeof value == 'string'){value = parseLodash(n); } if(value[0] == '200'){var keyarray = key.split(’_’);var key0 = keyarray[0];var key1 = keyarray[1];var key2 = keyarray[2];_.forIn(_.keys(value[2]), function(v,k) { if (!bodyDatas[key0]) {bodyDatas[key0] = []; } if (!bodyDatas[key0][key1]) {bodyDatas[key0][key1] = []; }}); }else{console.log('取到數據頭部:'+n[0]); }}) console.log(bodyDatas['mx']);
上面這段代碼是用的數組,會有默認類型為undefine的值雖然我用對象換數組的方式解決了這個問題,但是心里始終存在疑問:為什么使用數組時,會添加了類型為undefine的值,這個值又不存在。我這個循環確實只執行了一次,那么可能是我的數組聲明方式有問題,里面有個默認的值?應該如何聲明?
問題解答
回答1:可以參考這個問題/q/10...
相關文章:
1. angular.js - angular內容過長展開收起效果2. docker網絡端口映射,沒有方便點的操作方法么?3. docker - 各位電腦上有多少個容器啊?容器一多,自己都搞混了,咋辦呢?4. docker綁定了nginx端口 外部訪問不到5. nignx - docker內nginx 80端口被占用6. fragment - android webView 返回后怎么禁止重新渲染?7. docker不顯示端口映射呢?8. php - mysql 模糊搜索問題9. java - 為什么此私有靜態變量能被訪問呢?10. php - 第三方支付平臺在很短時間內多次異步通知,訂單多次確認收款
