JavaScript Operadores relacionales (<, <=,>,> =)


Ejemplo

Cuando ambos operandos son numéricos, se comparan normalmente:

1 < 2        // true
2 <= 2       // true
3 >= 5       // false
true < false // false (implicitly converted to numbers, 1 > 0)

Cuando ambos operandos son cadenas, se comparan lexicográficamente (de acuerdo con el orden alfabético):

'a' < 'b'    // true
'1' < '2'    // true
'100' > '12' // false ('100' is less than '12' lexicographically!)

Cuando un operando es una cadena y el otro es un número, la cadena se convierte en un número antes de la comparación:

'1' < 2      // true
'3' > 2      // true
true > '2'   // false (true implicitly converted to number, 1 < 2)

Cuando la cadena no es numérica, la conversión numérica devuelve NaN (no es un número). Comparando con NaN siempre devuelve false :

1 < 'abc'    // false
1 > 'abc'    // false

Pero tenga cuidado al comparar un valor numérico con cadenas null , undefined o vacías:

1 > ''        // true
1 < ''        // false
1 > null      // true
1 < null      // false
1 > undefined // false
1 < undefined // false

Cuando un operando es un objeto y el otro es un número, el objeto se convierte en un número antes de la comparación. Por lo tanto, null es un caso particular porque Number(null);//0

new Date(2015)< 1479480185280            // true
null > -1                                //true
({toString:function(){return 123}}) > 122  //true