-
Notifications
You must be signed in to change notification settings - Fork 856
/
Copy pathfilter-implement.js
68 lines (48 loc) · 1.7 KB
/
filter-implement.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
// Problem-1 Filter even numbers
let numberArray = [1,2,3,4,5,6,7,8,9,10];
let evenNumbers = [];
for (let i = 0; i < numberArray.length; i++) {
if (numberArray[i] % 2 === 0) {
evenNumbers.push(numberArray[i]);
}
}
// console.log(evenNumbers);
let evenNumbersWithFilter = numberArray.filter((item) => (item % 2 === 0));
// console.log(evenNumbersWithFilter);
// Problem 2:- Filter objects with tags javascript
var persons = [
{id : 1, name : "John", tags : "javascript"},
{id : 2, name : "Alice", tags : "javascript"},
{id : 3, name : "Roger", tags : "java"},
{id : 4, name : "Adam", tags : "javascript"},
{id : 5, name : "Alex", tags : "java"}
];
let jsTags = persons.filter((item) => (item.tags === "javascript"))
// console.log(jsTags);
// Problem 2 with indexOf
let jsTags2 = persons.filter((item) => (item.tags.indexOf("javascript") > -1));
// console.log(jsTags2);
// Other example - traverses an array and inserts non-duplicate elements into a new array. That is, if an element is duplicated, then only insert that element once into the final newArray
function findNonDuplicates (array) {
let models = [];
for(var i = 0; i < array.length; i++) {
if(array.indexOf(array[i]) === i) {
models.push(array[i]);
}
}
return models;
}
let arr = [1, 2, 3, 4.4, 2];
// console.log(findNonDuplicates((arr)));
// using filter
function findNonDuplicatesFilter (array) {
return array.filter((elem, index, arr) => {
return array.indexOf(elem) === index;
})
}
// console.log(findNonDuplicatesFilter(arr));
// Write a function that returns the number of zeros in a given array?
noOfZeros = arr => {
return arr.filter(zero => (zero === 0)).length
}
console.log(noOfZeros([1, 2, 0, 0, 5]));