所谓操作符,就是用来操作数据值的符号,在JAVAScript中包括算术操作符、位操作符、关系操作符和相等操作符。这些操作符可以操作所有类型的数据,比如字符串、数字、布尔值,甚至对象。
所谓一元操作符就是只能对一个数据值进行操作,比如(递增、递减)操作符。
递增、递减操作符是直接借鉴C语言的,它分前置型和后置型。前置就是操作符在要操作的变量之前,后置在变量之后。
如下示例:
// 前置型
let age = 20;
++age; // 递增
console.log(age); // 结果输出21
--age;//递减
console.log(age); // 结果输出20
如上面例子,age通过++操作符递增变成21,又通过--操作符递减变成20;上面的操作等同下面的操作:
// 后置型
let age = 20;
age = age + 1; // 加1
age = age -1; // 减1
同理使用后置操作符会得到上面同样的结果,但是前置和后置有区别。前置操作符在语句被求值以前改变,后置是在语句被求值后改变。通过下面的例子看下其区别:
// 前置
let age = 20;
let anotherAge = --age + 5;
alert(age); // 输出19
alert(anotherAge); // 输出24
由于前置操作符的优先级和执行语句相等,因此会从左到右依次求值。上面的--age 会先进行递减操作,再继续后面的 + 5 运算,所以结果是24。
// 后置时
let age = 20;
let anotherAge = age-- + 5;
alert(age); // 输出19
alert(anotherAge); // 输出25
但是后置的最终结果却是25,因为age-- 使用了递减前的值继续和后面进行+5运算。
如果使用一个加号或减号时,加号代表正值、减号代表负值。
操作多个数据值,比如加减乘除等:
let a = 1,b=2;
let c = a + b; // 加
let d = c - a; // 减
let e = d * b; // 乘
let f = e/d; // 除
注意加减乘除主要用来操作数字类型的数据,如果操作数不是数字类型,会先进性强制转换再进行计算,这样结果会不确定。
位操作符,是指按内存中的表示的数值位来操作数值,通俗讲就是用来操作二进制的数据。二进制数据都是由0、1组成的,在JavaScript中所有数值都是64位的格式存储,但位操作符不直接在64位的值上进行计算,会先转化成32位后再运算。位操作符有以下几种:
按位非(NOT)
按位非操作符是(~)符号,就是将二进制中每位数值进行反码操作。其规则如下:
操作符 |
数值 |
结果 |
~ |
1 |
0 |
~ |
0 |
1 |
如下示例:
let a = 25;
let b = ~a;
alert(b); // 输出-26
按位与(AND)
使用(&)符号表示,它有2个操作数,当2个数对应的位都是1时返回1,任何一位是0则返回0。如下规则:
数值1 |
操作符 |
数值2 |
结果 |
1 |
& |
1 |
1 |
1 |
& |
0 |
0 |
0 |
& |
1 |
0 |
0 |
& |
0 |
0 |
示例:
let a = 25 & 3;
alert(a); // 输出结果是1
按位或(OR)
用(|)符号表示,同样也是2个操作数。其规则是只要有一位是1其结果就是1,负则结果是0;
数值1 |
操作符 |
数值2 |
结果 |
1 |
| |
1 |
1 |
1 |
| |
0 |
1 |
0 |
| |
1 |
1 |
0 |
| |
0 |
0 |
示例:
let a = 25 | 3;
alert(a); // 输出结果是27
按位异或(XOR)
由(^)符号表示,也是操作2个操作数,其当2个操作数的位值相同时返回0,负则返回1。
数值1 |
操作符 |
数值2 |
结果 |
1 |
^ |
1 |
0 |
1 |
^ |
0 |
1 |
0 |
^ |
1 |
1 |
0 |
^ |
0 |
0 |
示例:
let a = 25 ^ 3;
alert(a); // 输出结果是26
左移
使用(<<)两个小于号表示,这个操作符会将数值每一位向左移动指定位数。如下示例:
let a = 2; // 二进制 10
let b = b << 5; // 二进制的 1000000,十进制64
上面,将二进制10向左移动5位,注意左移会多出5个空位,用0来填充,这样就会得到一个完整的32位二进制数据。
注意,左移不会影响符号位(二进制位中第一位表示数的正负),如-2 向左移5位结果是-64。
有符号的右移
使用(>>)两个大于号表示,会将每位向右移动指定位数,但保留符号位(即正负号标记)。如下示例:
let a = 64; // 二进制 1000000
let b = b >> 5; // 二进制的 10,十进制的2
在移位过程,原数中也会出现空位,只不过这次空位出现在原数值左侧、符号位右侧。空位使用符号位值填充。
有符号的整数,指32位中前31位表示整数的值,第32位表示数值的符号,0正数,1负数。这个表示符号的位就是符号位。
无符号的右移
使用(>>>)三个大于号表示,这个操作会将所有32位都向右移动。对于正数其结果和有符号的右移一样,如下示例:
let a = 64; // 二进制 1000000
let b = b >>> 5; // 二进制的 10,十进制的2
但是负数就不一样了,无符号的右移是以0来填充空位,不像有符号右移使用符号位填充。所以其结果相差很大,如下示例:
let a = -64; // 二进制 1111 1111 1111 1111 1111 1111 1100 0000
let b = b >>> 5; // 二进制 0000 0111 1111 1111 1111 1111 1111 1110 ,十进制的134217726
在任何编程语言中,布尔操作符都是非常重要的,它是用来判断逻辑的关键,布尔操作符一共有三种:非(NOT)、与(AND)、或(OR)。
逻辑非
使用(!)感叹号表示逻辑非,其规则就是:
操作符 |
逻辑值 |
结果 |
! |
true |
false |
! |
false |
true |
逻辑与
使用(&&)表示,操作两个数,如下示例:
let a = ture && false;
其规则如下:
逻辑值1 |
操作符 |
逻辑值2 |
结果 |
ture |
&& |
ture |
ture |
ture |
&& |
false |
false |
false |
&& |
ture |
false |
false |
&& |
false |
false |
也就是只有当2个数值都是true时其结果才是true。
逻辑或
使用(||)符号表示,也是有两个操作数,其示例:
let a = true || false;
规则如下:
逻辑值1 |
操作符 |
逻辑值2 |
结果 |
ture |
|| |
ture |
ture |
ture |
|| |
false |
ture |
false |
|| |
ture |
ture |
false |
|| |
false |
false |
也就是2个操作数中有一个true,结果就是true,负则是false。
注意布尔操作符,不仅仅可以操作布尔类型值,对于其它数据类型同样适用,只不过会先将其它数据类型转换成布尔值,再进行布尔运算。如下示例:
let a = !1; // 输出false
let b = !'string'; // 输出false
let c = 1 || 0; // 输出true
let e = 1 && 0;// 输出false
let d = ''&& 2; // 输出true
关系操作符用来比较2个操作数,有小于(<)、大于(>)、小于等于(<=)和大于等于(>=)。其比较的结果返回一个布尔值,true或false。
如下示例:
let a = 5 > 3; // true
let b = 5 < 3; // false
同样,关系操作符也可以适用其它类型的数据,比如字符串比较大小时,会按照字符的编码大小比较。如下示例:
let a = "Brick" < "alphabet"; // true,
上面中因为B字符编码是66,a的编码是97,所以返回true。
在编程中,确定2个值是否相等是一个非常重要的操作。在JavaScript中分相等(==)和全等(===)、不等(!=)和不全等(!==)四种。
相等(==)和不相等(!=)
如下示例:
let a = 1 == 1; // true
let b = 1==0;// false
let c = 1!=1; // false
let d = 1!=0; //true
注意相等和不相等的操作前会先对操作性进行强制转换,如下示例:
let a = true == 1; // 先将true转换成1再比较,结果是true
let b = false == 1; // 先将false转换成0再比较,结果是false
全相等(===)和不全相等(!==)
全等和不全等不同之处是,它在比较数据前,不进行数据类型转换,是对原始数值比较,所以它的结果更加严格准确,如下示例:
let a = 1 === 1; // true
let b = 1=== '1';// false
let c = 1!==1; // false
let d = 1!=='1'; //true
注意和之前相等和不相等的例子比较,其结果非常不一样。
使用(=)表示赋值操作,其作用就是把等号右侧的值赋值给左边的变量或属性,如下示例:
let a = 10; // 给a变量赋值10
如果在等号前面加上其它操作符,就组成了复合型赋值操作,如下示例:
let a = 10;
a += 5; // 结果是 15
上面的等同于下面:
let a = 10;
a = a + 5; // 结果是 15
当然也可以使用其它操作符,如(*=)、(/=)、(%=)、(-=)、(<<=)等等。
也称三目运算符,它是一种简便的条件运算,可以把它看成是if else的简化,其语法如下:
变量 = 布尔表达式 ? true_value : false_value
先求出问号前面的布尔表示结果,如果是true,变量使用冒号前面的值,负则使用冒号后面的值。如下示例:
let a = 5 > 3 ? '好' : '不好'; // 结果是 '好'
使用(,)符号,表示可以执行多个操作,常用于变量定义或函数参数,如下示例:
var a = 0,b=1,c=2; // a、b、c使用逗号隔开
let a,b,c;
// 函数中的参数a、b、c使用逗号隔开
function test(a,b,c){
// 函数主体
}
// 调用函数
test(1,2,3)
本节主要讲述了JavaScript中所有的操作符概念,这些都是最基本的知识,需要完全掌握。在平常工作中其中除了位操作符不常用外,其它操作符使用频率很高,尤其是布尔操作符,算术操作符,比较操作符等。
本篇只是大概讲述了操作符的概念和使用方法,还有一些细节没有讲到,作为入门课程已经足够了,你可以自己搜索每个知识点详细内容,比如关于二进制数据、位操作、数据类型强制转换等,这里不再详细介绍。
《JavaScript 高级程序设计》
https://developer.mozilla.org/zh-CN/docs/Web/JavaScript
https://www.w3cschool.cn/javascript/js-operators.html