How does “+var === +var” work internally to verify if var is numeric?

…衆ロ難τιáo~ 提交于 2019-12-04 14:56:36

问题


Seeing this question: Is there a (built-in) way in JavaScript to check if a string is a valid number? and this: jsperf, one of the presented approaches is this (mutatis mutandis):

var a = "123"
var b = "123b"

if ( +a === +a ) // true

if ( +b === +b ) // false

How does this logic work internally in JavaScript to make this possible?

My question is not how to check if a string is a valid number – this is already answered here: Validate decimal numbers in JavaScript - IsNumeric(). I want to understand how the statement +a === +a works.


回答1:


+ converts the value to a number.

a gets converted to 123 and 123 === 123.

b gets converted to NaN but NaN !== NaN (because NaN is never equal to another NaN according step 4a of the equality rules).




回答2:


The + operator here is known as the Unary Plus.

The unary plus operator precedes its operand and evaluates to its operand but attempts to converts it into a number, if it isn't already.

+"123" evaulates as 123.

+a === +a
-> +"123" === +"123"
  -> 123 === 123
    -> true

+"123b" evaluates as NaN (Not a Number), as the b character cannot be converted with the Unary Plus as without any prefix (like 0x for hexadecimal) the Unary Plus will assume the value is decimal (0-9). NaN is a special case in that it does not compare against anything, including itself:

NaN === NaN
-> false

NaN !== NaN
-> true

Because of this, our +b test case fails:

+b === +b
-> +"123b" === +"123b"
  -> NaN === NaN
    -> false

If you want both to evaluate to true we can add an isNaN() call at the end:

if ( +a === +a || isNaN(+a) )

if ( +b === +b || isNaN(+b) )



回答3:


+"123b" is NaN. NaN is not equal to anything, including NaN.




回答4:


The two variables are string, but javascript convert automatically any string to a number when you + or - .

var a = "1";
var b = a;     // b = "1": a string
var c = +a;    // c = 1: a number
var d = -a;    // d = -1: a number

and Basically in your example you try to do this:

if ( +"123" === +"123" )  => ( 123 === 123) // true
if ( +"123b" === +"123b" ) => (NaN === NaN) // false


来源:https://stackoverflow.com/questions/30192893/how-does-var-var-work-internally-to-verify-if-var-is-numeric

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!