四.关系运算符:用于进行比较的运算符称作为关系运算符:小于(<)、大于(>)、小于等于(<=)、大于等于(>=)、相等(==)、不等(!=)、全等(恒等)(===)、不全等(不恒等)(!==)
和其他运算符一样,当关系运算符操作非数值时要遵循一下规则:
1.两个操作数都是数值,则数值比较;
2.两个操作数都是字符串,则比较两个字符串对应的字符编码值;
3.两个操作数有一个是数值,则将另一个转换为数值,再进行数值比较;
4.两个操作数有一个是对象,则先调用
valueOf()方法或 toString()方法,再用结果比较;
var box = 3 > 2; //true
var box
= 3 > 22; //false
var box = ‘3‘ > 22; //false
var box = ‘3‘
> ‘22‘; //true
var box = ‘a‘ > ‘b‘; //false a=97,b=98
var box
= ‘a‘ > ‘B‘; //true B=66
var box = 1 > 对象; //false,如果有 toString()或
valueOf()则返回 1 > 返回数的值
在相等和不等的比较上,如果操作数是非数值,则遵循一下规则:
1.一个操作数是布尔值,则比较之前将其转换为数值,false 转成 0,true 转成
1;
2.一个操作数是字符串,则比较之前将其转成为数值再比较;
3.一个操作数是对象,则先调用 valueOf()或
toString()方法后再和返回值比较;
4.不需要任何转换的情况下,null 和 undefined 是相等的;
5.一个操作数是
NaN,则==返回 false,!=返回 true;并且 NaN
和自身不等;
6.两个操作数都是对象,则比较他们是否是同一个对象,如果都指向同一个对象,则返回 true,否则返回
false。
7.在全等和全不等的判断上,比如值和类型都相等,才返回 true,否则返回 false。
var box = 2 == 2;
//true
var box = ‘2‘ == 2; //true,‘2‘会转成成数值 2
var box = false == 0;
//true,false 转成数值就是 0
var box = ‘a‘ == ‘A‘; //false,转换后的编码不一样
var
box = 2 == {}; //false,执行 toString()或 valueOf()会改变
var box = 2 == NaN;
//false,只要有 NaN,都是 false
var box = {} == {};
//false,比较的是他们的地址,每个新创建对象的引用地址都不同
var age = {};
var height =
age;
var box = age == height; //true,引用地址一样,所以相等
var box = ‘2‘ === 2
//false,值和类型都必须相等
var box = 2 !== 2 //false,值和类型都相等了
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2 <html xmlns="http://www.w3.org/1999/xhtml">
3 <head>
4 <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
5 <title>运算符</title>
6 <script type="text/javascript">
7 /*
8 var box = 3 > 2;
9 alert(box);//true
10
11 var box = 3 > 22;
12 alert(box);//false
13
14 var box = ‘3‘ > 22;
15 alert(box);//false
16
17 var box = ‘3‘ > ‘22‘;
18 alert(box);//true
19
20 var box = ‘a‘ > ‘b‘;
21 alert(box);//false a=97,b=98
22
23 var box = ‘a‘ > ‘B‘;
24 alert(box);//true B=66
25
26 var box = 1 > {};
27 alert(box);//false,如果有 toString()或 valueOf()则返回 1 > 返回数的值
28 */
29
30 /*
31 var box = 2 == 2;
32 alert(box);//true
33
34 var box = ‘2‘ == 2;
35 alert(box);//true,‘2‘会转成成数值 2
36
37 var box = false == 0;
38 alert(box);//true,false 转成数值就是 0
39
40 var box = ‘a‘ == ‘A‘;
41 alert(box);//false,转换后的编码不一样
42
43 var box = 2 == {};
44 alert(box);//false,执行 toString()或 valueOf()会改变
45
46 var box = 2 == NaN;
47 alert(box);//false,只要有 NaN,都是 false
48
49 var box = {} == {};
50 alert(box);//false,比较的是他们的地址,每个新创建对象的引用地址都不同
51
52 var age = {};
53 alert(age);
54 var height = age;
55 alert(age);
56 var box = age == height;
57 alert(box);//true,引用地址一样,所以相等
58
59 var box = ‘2‘ === 2;
60 alert(box);//false,值和类型都必须相等
61
62 var box = 2 !== 2;
63 alert(box);//false,值和类型都相等了
64 */
65 </script>
66 </head>
67
68 <body>
69 欢迎来到javascript的世界
70 </body>
71 </html>