<返回更多

前端入门——JavaScript 操作符

2022-07-18    前端石三
加入收藏

所谓操作符,就是用来操作数据值的符号,在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

声明:本站部分内容来自互联网,如有版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
▍相关推荐
更多资讯 >>>