JS Home JS Reference Comparison

*Comparison* operators

Used when we want to compare operands.

### Description

Comparison operators allow us to compare operands in various ways.

Operands can be numerical or string values and are compared by standard lexicographical ordering using Unicode values.

`null`

and `undefined`

types are equal but not strictly equal.

## Type Converting Comparators

These comparators attempt to convert the operands for comparison.

`==`

Equal

`!=`

Not equal

`<`

Less than

`<=`

Less than or equal

`>`

Greater than

`>=`

Greater than or equal

### Type Converting Rules

`null`

and `undefined`

types are equal.

#### Number and String Comparison

The string is converted to a number value and then JavaScript attempts to convert the string numeric literal to a `Number`

type as follows:

- A mathematical value is derived from the string numeric literal.
- The value is rounded to the nearest
`Number`

type value.

#### Boolean Comparison

For boolean conversion the following happens:

- If the boolean value is
`true`

it is converted to the number 1 - If the boolean value is
`false`

it is converted to the number +0

#### Object Comparison

For object conversion where both operands are objects no conversion takes place. The equality test is true only if both objects refer to the same object, otherwise object conversion applies as follows:

- JavaScript attempts to return the default value for the object when compared with a number or string.
- The
`toString`

and`valueOf`

are used to convert the object to a primitive value, a`Number`

or`String`

value. If this attempt to convert the object fails, a runtime error is generated.

### Equal comparator `==`

The equal comparator returns `true`

if the operands are equal and does the following before comparing the two operands.

For operands of different types, JavaScript converts the operands then applies strict comparison via the *===* operator in the following order.

- Where either operand is a number or boolean, both operands are converted to numbers when possible.
- Where either operand is a string, the other operand is converted to a string when possible.
- When both operands are JavaScript objects , they are equal when both equate to the same memory reference.

### Examples

The code below does some equality comparison.

```
//Create and compare some variables
```**var aVariable = 1, bVariable = '1', cVariable = true;
// The string value of bVariable converted to 1 so true
if (aVariable == bVariable) {
alert('true');
} else {
alert('false');
}**
// The boolean value of cVariable converted to 1 so true}
**if (aVariable == cVariable) {
alert('true');
} else {
alert('false');
}**
// The boolean value of cVariable converted to 1 and
// then string value of bVariable converted to 1 so true}
**if (bVariable == cVariable) {
alert('true');
} else {
alert('false');
}**

### Not Equal comparator `!=`

The not equal comparator returns `true`

if the operands are NOT equal and does the following before comparing the two operands.

For operands of different types, JavaScript attempts to convert an appropriate comparison type. When both operands are JavaScript objects , they are not equal when both equate to different memory references.

### Examples

The code below does some inequality comparisons.

```
//Create and compare some variables for inequality
```**var aVariable = 1, bVariable = '1', cVariable = true;
// The string value of bVariable converted to 1 so false
if (aVariable != bVariable) {
alert('true');
} else {
alert('false');
}**
// The boolean value of cVariable converted to 1 so false
**if (aVariable != cVariable) {
alert('true');
} else {
alert('false');
}**
// The boolean value of cVariable converted to 1 and
// then string value of bVariable converted to 1 so false
**if (bVariable != cVariable) {
alert('true');
} else {
alert('false');
}**

### Less than comparator `<`

Returns `true`

if the left operand is less than the right operand.

### Less than or equal comparator `<=`

Returns `true`

if the left operand is less than or equal to the right operand.

### Greater than comparator `>`

Returns `true`

if the left operand is greater than the right operand.

### Greater than or equal comparator `>=`

Returns `true`

if the left operand is greater than or equal to the right operand.

## Strict Comparators

These comparators must have the same type.

`===`

Strict equal

`!==`

Strict not equal

### Strict Comparison Rules

`null`

and `undefined`

types are not strictly equal.

#### Number Comparison

Numbers are strictly equal when they have the same numerical value.

`NaN()`

is not equal to anything, including`NaN`

.- Positive and negative zeros are equal.

#### Boolean Comparison

Booleans are strictly equal if both are `true`

or `false`

#### String Comparison

Strings are strictly equal when they have the same sequence of characters, in the same positions with the same length.

#### Object Comparison

Objects are strictly equal if they refer to the same object.

## Related Tutorials

JavaScript Intermediate Tutorials - Lesson 3 - Conditional Statements