Why Array.filter(Number) filters zero out in javascript?
I'm trying to filter all non-numeric out from array. We can see desired output when using typeof. But with Number, it filters zero out.
Here's the example (tested in Chrome Console):
[-1, 0, 1, 2, 3, 4, Number(0), '', 'test'].filter(Number)
// Which output with zero filtered out:
[-1, 1, 2, 3, 4] // 0 is filtered
If we use type of, it doesn't filter zero, which was expected
// code
[-1, 0, 1, 2, 3, 4, Number(0), '', 'test'].filter(n => typeof n === 'number')
// output
[-1, 0, 1, 2, 3, 4, 0]
My question:
What is the difference between the 'Number' and 'type of' approach?
Number filter zero, but 'Number' itself literally containing zero, and this makes me confusing.
javascript numbers typeof
New contributor
add a comment |
I'm trying to filter all non-numeric out from array. We can see desired output when using typeof. But with Number, it filters zero out.
Here's the example (tested in Chrome Console):
[-1, 0, 1, 2, 3, 4, Number(0), '', 'test'].filter(Number)
// Which output with zero filtered out:
[-1, 1, 2, 3, 4] // 0 is filtered
If we use type of, it doesn't filter zero, which was expected
// code
[-1, 0, 1, 2, 3, 4, Number(0), '', 'test'].filter(n => typeof n === 'number')
// output
[-1, 0, 1, 2, 3, 4, 0]
My question:
What is the difference between the 'Number' and 'type of' approach?
Number filter zero, but 'Number' itself literally containing zero, and this makes me confusing.
javascript numbers typeof
New contributor
add a comment |
I'm trying to filter all non-numeric out from array. We can see desired output when using typeof. But with Number, it filters zero out.
Here's the example (tested in Chrome Console):
[-1, 0, 1, 2, 3, 4, Number(0), '', 'test'].filter(Number)
// Which output with zero filtered out:
[-1, 1, 2, 3, 4] // 0 is filtered
If we use type of, it doesn't filter zero, which was expected
// code
[-1, 0, 1, 2, 3, 4, Number(0), '', 'test'].filter(n => typeof n === 'number')
// output
[-1, 0, 1, 2, 3, 4, 0]
My question:
What is the difference between the 'Number' and 'type of' approach?
Number filter zero, but 'Number' itself literally containing zero, and this makes me confusing.
javascript numbers typeof
New contributor
I'm trying to filter all non-numeric out from array. We can see desired output when using typeof. But with Number, it filters zero out.
Here's the example (tested in Chrome Console):
[-1, 0, 1, 2, 3, 4, Number(0), '', 'test'].filter(Number)
// Which output with zero filtered out:
[-1, 1, 2, 3, 4] // 0 is filtered
If we use type of, it doesn't filter zero, which was expected
// code
[-1, 0, 1, 2, 3, 4, Number(0), '', 'test'].filter(n => typeof n === 'number')
// output
[-1, 0, 1, 2, 3, 4, 0]
My question:
What is the difference between the 'Number' and 'type of' approach?
Number filter zero, but 'Number' itself literally containing zero, and this makes me confusing.
javascript numbers typeof
javascript numbers typeof
New contributor
New contributor
New contributor
asked 1 hour ago
imckl
433
433
New contributor
New contributor
add a comment |
add a comment |
4 Answers
4
active
oldest
votes
Because 0
is one of the many falsy
values in javascript
All these conditions will be sent to else
blocks:
if (false)
if (null)
if (undefined)
if (0)
if (NaN)
if ('')
if ("")
if (``)
From the Array.prototype.filter()
documentation:
filter()
calls a providedcallback
function once for each element in an array, and constructs a new array of all the values for which callback returns a value that coerces to true
In your case the callback function is the Number
. So your code is equivalent to:
[-1, 0, 1, 2, 3, 4, Number(0), '', 'test'].filter(a => Number(a))
Thanks for the detailed explanation! Marked as accepted :)
– imckl
1 hour ago
add a comment |
Zero is a falsey value. The typeof is always returning a boolean value. When the number 0 is returned, it is returning to the test, and therefore coming back as false, so the number zero is filtered out.
add a comment |
When you're using Number in filter, Actually it is passing each item of Array to Number constructor and in case of string or 0 Number will return NaN or 0 and both of them are false so filter is filtering out both of them
whereas when you're using typeof then 0 has "number" type so it is returning true and filter method doesn't filtering it out
1
This answer with @adiga falsy explanation solves my confusing :)
– imckl
1 hour ago
add a comment |
It's because 0 is a falsy value which returns false
Documentation
https://developer.mozilla.org/en-US/docs/Glossary/Falsy
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
imckl is a new contributor. Be nice, and check out our Code of Conduct.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53920037%2fwhy-array-filternumber-filters-zero-out-in-javascript%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
4 Answers
4
active
oldest
votes
4 Answers
4
active
oldest
votes
active
oldest
votes
active
oldest
votes
Because 0
is one of the many falsy
values in javascript
All these conditions will be sent to else
blocks:
if (false)
if (null)
if (undefined)
if (0)
if (NaN)
if ('')
if ("")
if (``)
From the Array.prototype.filter()
documentation:
filter()
calls a providedcallback
function once for each element in an array, and constructs a new array of all the values for which callback returns a value that coerces to true
In your case the callback function is the Number
. So your code is equivalent to:
[-1, 0, 1, 2, 3, 4, Number(0), '', 'test'].filter(a => Number(a))
Thanks for the detailed explanation! Marked as accepted :)
– imckl
1 hour ago
add a comment |
Because 0
is one of the many falsy
values in javascript
All these conditions will be sent to else
blocks:
if (false)
if (null)
if (undefined)
if (0)
if (NaN)
if ('')
if ("")
if (``)
From the Array.prototype.filter()
documentation:
filter()
calls a providedcallback
function once for each element in an array, and constructs a new array of all the values for which callback returns a value that coerces to true
In your case the callback function is the Number
. So your code is equivalent to:
[-1, 0, 1, 2, 3, 4, Number(0), '', 'test'].filter(a => Number(a))
Thanks for the detailed explanation! Marked as accepted :)
– imckl
1 hour ago
add a comment |
Because 0
is one of the many falsy
values in javascript
All these conditions will be sent to else
blocks:
if (false)
if (null)
if (undefined)
if (0)
if (NaN)
if ('')
if ("")
if (``)
From the Array.prototype.filter()
documentation:
filter()
calls a providedcallback
function once for each element in an array, and constructs a new array of all the values for which callback returns a value that coerces to true
In your case the callback function is the Number
. So your code is equivalent to:
[-1, 0, 1, 2, 3, 4, Number(0), '', 'test'].filter(a => Number(a))
Because 0
is one of the many falsy
values in javascript
All these conditions will be sent to else
blocks:
if (false)
if (null)
if (undefined)
if (0)
if (NaN)
if ('')
if ("")
if (``)
From the Array.prototype.filter()
documentation:
filter()
calls a providedcallback
function once for each element in an array, and constructs a new array of all the values for which callback returns a value that coerces to true
In your case the callback function is the Number
. So your code is equivalent to:
[-1, 0, 1, 2, 3, 4, Number(0), '', 'test'].filter(a => Number(a))
edited 1 hour ago
answered 1 hour ago
adiga
5,64361938
5,64361938
Thanks for the detailed explanation! Marked as accepted :)
– imckl
1 hour ago
add a comment |
Thanks for the detailed explanation! Marked as accepted :)
– imckl
1 hour ago
Thanks for the detailed explanation! Marked as accepted :)
– imckl
1 hour ago
Thanks for the detailed explanation! Marked as accepted :)
– imckl
1 hour ago
add a comment |
Zero is a falsey value. The typeof is always returning a boolean value. When the number 0 is returned, it is returning to the test, and therefore coming back as false, so the number zero is filtered out.
add a comment |
Zero is a falsey value. The typeof is always returning a boolean value. When the number 0 is returned, it is returning to the test, and therefore coming back as false, so the number zero is filtered out.
add a comment |
Zero is a falsey value. The typeof is always returning a boolean value. When the number 0 is returned, it is returning to the test, and therefore coming back as false, so the number zero is filtered out.
Zero is a falsey value. The typeof is always returning a boolean value. When the number 0 is returned, it is returning to the test, and therefore coming back as false, so the number zero is filtered out.
answered 1 hour ago
bronkula
287
287
add a comment |
add a comment |
When you're using Number in filter, Actually it is passing each item of Array to Number constructor and in case of string or 0 Number will return NaN or 0 and both of them are false so filter is filtering out both of them
whereas when you're using typeof then 0 has "number" type so it is returning true and filter method doesn't filtering it out
1
This answer with @adiga falsy explanation solves my confusing :)
– imckl
1 hour ago
add a comment |
When you're using Number in filter, Actually it is passing each item of Array to Number constructor and in case of string or 0 Number will return NaN or 0 and both of them are false so filter is filtering out both of them
whereas when you're using typeof then 0 has "number" type so it is returning true and filter method doesn't filtering it out
1
This answer with @adiga falsy explanation solves my confusing :)
– imckl
1 hour ago
add a comment |
When you're using Number in filter, Actually it is passing each item of Array to Number constructor and in case of string or 0 Number will return NaN or 0 and both of them are false so filter is filtering out both of them
whereas when you're using typeof then 0 has "number" type so it is returning true and filter method doesn't filtering it out
When you're using Number in filter, Actually it is passing each item of Array to Number constructor and in case of string or 0 Number will return NaN or 0 and both of them are false so filter is filtering out both of them
whereas when you're using typeof then 0 has "number" type so it is returning true and filter method doesn't filtering it out
answered 1 hour ago
Abhay Sehgal
16318
16318
1
This answer with @adiga falsy explanation solves my confusing :)
– imckl
1 hour ago
add a comment |
1
This answer with @adiga falsy explanation solves my confusing :)
– imckl
1 hour ago
1
1
This answer with @adiga falsy explanation solves my confusing :)
– imckl
1 hour ago
This answer with @adiga falsy explanation solves my confusing :)
– imckl
1 hour ago
add a comment |
It's because 0 is a falsy value which returns false
Documentation
https://developer.mozilla.org/en-US/docs/Glossary/Falsy
add a comment |
It's because 0 is a falsy value which returns false
Documentation
https://developer.mozilla.org/en-US/docs/Glossary/Falsy
add a comment |
It's because 0 is a falsy value which returns false
Documentation
https://developer.mozilla.org/en-US/docs/Glossary/Falsy
It's because 0 is a falsy value which returns false
Documentation
https://developer.mozilla.org/en-US/docs/Glossary/Falsy
edited 1 hour ago
answered 1 hour ago
AnonymousSB
2,149220
2,149220
add a comment |
add a comment |
imckl is a new contributor. Be nice, and check out our Code of Conduct.
imckl is a new contributor. Be nice, and check out our Code of Conduct.
imckl is a new contributor. Be nice, and check out our Code of Conduct.
imckl is a new contributor. Be nice, and check out our Code of Conduct.
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53920037%2fwhy-array-filternumber-filters-zero-out-in-javascript%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown