Remove empty elements from an array in Javascript

后端 未结 30 2270
无人共我
无人共我 2020-11-21 09:53

How do I remove empty elements from an array in JavaScript?

Is there a straightforward way, or do I need to loop through it and remove them manually?

相关标签:
30条回答
  • 2020-11-21 10:25

    You should use filter to get array without empty elements. Example on ES6

    const array = [1, 32, 2, undefined, 3];
    const newArray = array.filter(arr => arr);
    
    0 讨论(0)
  • 2020-11-21 10:26
    var data = [null, 1,2,3];
    var r = data.filter(function(i){ return i != null; })
    

    console.log(r) 
    

    [1,2,3]

    0 讨论(0)
  • 2020-11-21 10:28

    All the empty elements can be removed from an array by simply by using array.filter(String); It returns all non empty elements of an array in javascript

    0 讨论(0)
  • 2020-11-21 10:30

    Simple ways:

    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]
    

    or - (only for single array items of type "text")

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

    or - Classic way: simple iteration

    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]
    


    via 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]
    


    UPDATE - just another fast, cool way (using 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;
    
    arr // [1, 2, 3, 3, 4, 4, 5, 6]
    

    Remove empty values

    ['foo', '',,,'',,null, ' ', 3, true, [], [1], {}, undefined, ()=>{}].filter(String)
    
    // ["foo", null, " ", 3, true, [1], Object {}, undefined, ()=>{}]
    
    0 讨论(0)
  • 2020-11-21 10:30

    ES6:

    let newArr = arr.filter(e => e);
    
    0 讨论(0)
  • 2020-11-21 10:31

    If you need to remove ALL empty values ("", null, undefined and 0):

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

    To remove empty values and Line breaks:

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

    Example:

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

    Return:

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

    UPDATE (based on Alnitak's comment)

    In some situations you may want to keep "0" in the array and remove anything else (null, undefined and ""), this is one way:

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

    Return:

    ["hello", 0, 1, 100, " "]
    
    0 讨论(0)
提交回复
热议问题