亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

刪除Javascript中數組中的空元素

刪除Javascript中數組中的空元素

Helenr 2019-06-10 16:57:35
刪除Javascript中數組中的空元素如何從JavaScript數組中刪除空元素?是否有一種簡單的方法,或者我需要循環遍歷并手動刪除它們?
查看完整描述

3 回答

?
拉莫斯之舞

TA貢獻1820條經驗 獲得超10個贊

如果需要刪除所有空值(“、NULL、未定義和0):

arr = arr.filter(function(e){return e});

若要刪除空值和換行,請執行以下操作:

arr = arr.filter(function(e){ return e.replace(/(\r\n|\n|\r)/gm,"")});

例子:

arr = ["hello",0,"",null,undefined,1,100," "]  arr.filter(function(e){return e});

返回:

["hello", 1, 100, " "]

更新(根據Alnitak的評論)

在某些情況下,您可能希望將“0”保留在數組中并刪除任何其他內容(空、未定義和“),這是一種方法:

arr.filter(function(e){ return e === 0 || e });

返回:

["hello", 0, 1, 100, " "]


查看完整回答
1 反對 回復 2019-06-10
?
藍山帝景

TA貢獻1843條經驗 獲得超7個贊

當時在Array.prototype.


現在,我建議您使用filter方法。


請記住,此方法將返回您一種新的陣列使用傳遞回調函數的條件的元素,例如,如果要刪除null或undefined價值:


var array = [0, 1, null, 2, "", 3, undefined, 3,,,,,, 4,, 4,, 5,, 6,,,,];


var filtered = array.filter(function (el) {

  return el != null;

});


console.log(filtered);

這將取決于您認為什么是“空”的,例如,如果您處理的是字符串,上面的函數不會刪除空字符串的元素。


我經常看到的一個常見模式是刪除以下元素虛妄,其中包括空字符串。"", 0, NaN, null, undefined,和false.


您可以簡單地傳遞到filter方法,Boolean構造函數,或者簡單地返回篩選條件函數中的相同元素,例如:


var filtered = array.filter(Boolean);


var filtered = array.filter(function(el) { return el; });

這兩種方式都有效,因為filter方法,在第一種情況下,調用Boolean構造函數,轉換值,在第二種情況下,filter方法內部將回調的返回值隱式轉換為Boolean.


如果您正在處理稀疏數組,并且試圖消除“漏洞”,則只需使用filter傳遞返回true的回調的方法,例如:


var sparseArray = [0, , , 1, , , , , 2, , , , 3],

    cleanArray = sparseArray.filter(function () { return true });


console.log(cleanArray); // [ 0, 1, 2, 3 ]


查看完整回答
反對 回復 2019-06-10
?
慕俠2389804

TA貢獻1719條經驗 獲得超6個贊

簡單的方法:

var arr = [1,2,,3,,-3,null,,0,,undefined,4,,4,,5,,6,,,,];



arr.filter(n => n)

// [1, 2, 3, -3, 4, 4, 5, 6]


arr.filter(Number) 

// [1, 2, 3, -3, 4, 4, 5, 6]


arr.filter(Boolean) 

// [1, 2, 3, -3, 4, 4, 5, 6]

或-(只供單株類型為“text”的數組項)


['','1','2',3,,'4',,undefined,,,'5'].join('').split(''); 

// output:  ["1","2","3","4","5"]

或-經典方式:簡單的迭代


var arr = [1,2,null, undefined,3,,3,,,0,,,[],,{},,5,,6,,,,],

    len = arr.length, i;


for(i = 0; i < len; i++ )

    arr[i] && arr.push(arr[i]);  // copy non-empty values to the end of the array


arr.splice(0 , len);  // cut the array and leave only the non-empty values


arr // [1,2,3,3,[],Object{},5,6]



通過jQuery:

var arr = [1,2,,3,,3,,,0,,,4,,4,,5,,6,,,,];


arr = $.grep(arr,function(n){ return n == 0 || n });


arr // [1, 2, 3, 3, 0, 4, 4, 5, 6]



更新-只是另一種快速、酷的方法(使用ES6):

var arr = [1,2,null, undefined,3,,3,,,0,,,4,,4,,5,,6,,,,], 

    temp = [];


for(let i of arr)

    i && temp.push(i); // copy each non-empty value to the 'temp' array


arr = temp;

delete temp; // discard the variable


arr // [1, 2, 3, 3, 4, 4, 5, 6]

刪除空值

['foo', '',,,'',,null, ' ', 3, true, [], [1], {}, undefined, ()=>{}].filter(String)


// ["foo", null, " ", 3, true, [1], Object {}, undefined, ()=>{}]


查看完整回答
反對 回復 2019-06-10
  • 3 回答
  • 0 關注
  • 10429 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號