JavaScript运算符


1. 运算符

运算符(operator)也被称为操作符,是用于实现赋值、比较和执行算数运算等功能的符号。


2. 算数运算符

2.1 概述

概念:算术运算使用的符号,用于执行两个变量或值的算术运算。

运算符 描述 实例
+ 10 + 20 = 30
- 10 - 20 = -10
* 10 * 20 = 200
/ 10 / 20 = 0.5
% 取余数 返回除法的余数 9 % 2 = 1

2.2 浮点数的精度问题

浮点数值的最高精度是 17 位小数,但在进行算术计算时其精确度远远不如整数。
所以:不要直接判断两个浮点数是否相等!

Q1:怎么判断一个数能够被整除呢?
它的余数是0 就说明这个数能被整除,这就是% 取余运算符的主要用途。
Q2:请问1 + 2 * 3结果是?
结果是7,注意算术运算符优先级的,先乘除,后加减,有小括号先算小括号里面的。

2.3 表达式和返回值

表达式:是由数字、运算符、变量等以能求得数值的有意义排列方法所得的组合。
简单理解:是由数字、运算符、变量等组成的式子。
1 + 1 就是表达式
console.log(1 + 1); // 2 就是返回值
var num = 1 + 1; // 程序中,右边表达式计算完毕把返回值给左边


3. 递增和递减运算符

3.1 概述

如果需要反复给数字变量添加或减去1,可以使用递增(++)递减(--)运算符来完成。
在 JavaScript中,递增(++)和递减(--)既可以放在变量前面,也可以放在变量后面。放在变量前面时我们可以称为前置递增(递减)运算符,放在变量后面时,我们可以称为后置递增(递减)运算符。
注意:递增和递减运算符必须和变量配合使用。

3.2 概述

3.2.1 前置递增运算符

++num 前置递增,就是自加1,类似于num = num + 1,但是++num写起来更简单。
使用口诀:先自加,后返回值。

var p = 10;
console.log(++p + 10); // 21 先自加1,后返回11,所以是11+10
3.2.2 后置递增运算符

num++ 后置递增,就是自加1,类似于num = num + 1,但是num++写起来更简单。
注意:前置自增和后置自增 如果单独使用,效果是一样的。
使用口诀:先返回原值,后自加。

var age = 10;
console.log(age++ + 10); // 20 
console.log(age); // 11 先被使用后,再自加1

4. 比较运算符

概念:比较运算符(关系运算符)是两个数据进行比较时所使用的运算符,比较运算后,会返回一个布尔值(true/false)作为比较运算的结果。

运算符名称 说明 案例 结果
< 小于号 1 < 2 true
> 大于号 1 > 2 false
>= 大于等于号 2 >= 2 true
<= 小于等于号 3 <= 2 false
== 等号(会转型) 18 == '18' true
!= 不等号 18 != 18 false
=== !== 全等 要求值和数据类型都一致 18 === '18' false

5. 逻辑运算符

5.1 概述

概念:逻辑运算符是用来进行布尔值运算的运算符,其返回值也是布尔值。后面开发中经常用于多个条件的判断。

逻辑运算符 说明
&& “逻辑与”,与 and
|| “逻辑或”,或 or
! “逻辑非”,非 not

5.2 逻辑与或非

&&:
两侧都是true才返回true,否则返回false。(只要有一侧为false,结果就是false)
||:
两侧都是false才返回false,否则返回true。(只要有一侧为true,结果就是true)
!:
逻辑非(!)也叫作取反符,用来取一个布尔值相反的值,如true的相反值是false。

5.3 短路运算(逻辑中断)

短路运算的原理:
当有多个表达式(值)时左边的表达式值可以确定结果时,就不再继续运算右边的表达式的值。

5.3.1 逻辑与 短路运算
  • 语法:表达式1 && 表达式2
  • 如果表达式1结果为真,则返回表达式2
  • 如果表达式1结果为假,则返回表达式1

注:如果有空的 或者否定的 为假,其余是真的。0 '' null undefined NaN

5.3.2 逻辑或 短路运算
  • 语法:表达式1 || 表达式2
  • 如果表达式1结果为真,则返回表达式1
  • 如果表达式1结果为假,则返回表达式2

6. 赋值运算符

概念:用来把数据赋值给变量的运算符。

赋值运算符 说明 案例
= 直接赋值 var name='007'
+=、-= 加、减一个数 后再赋值 var age = 10; age += 5; // 15
*=、/=、%= 乘、除、取模 后再赋值 var age = 2; age *= 5; // 10

var age =10;
age += 5; // 相当于 age = age + 5;
age -= 5; // 相当于age = age - 5;
age *= 10; // 相当于age = age * 10;


7. 运算符优先级

优先级 运算符 顺序
1 小括号 ()
2 一元运算符 ++ -- !
3 算数运算符 先* / % 后 + -
4 关系运算符 >、>=、<、<=
5 相等运算符 ==、!=、 ===、!==
6 逻辑运算符 先 && 后 ||
7 赋值运算符 =
8 逗号运算符 ,
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,088评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,715评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,361评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,099评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,987评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,063评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,486评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,175评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,440评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,518评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,305评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,190评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,550评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,152评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,451评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,637评论 2 335

推荐阅读更多精彩内容

  • 一、运算符 运算符(operator)也被称为操作符,是用于实现赋值、比较和执行算数运算等功能的符号。 JavaS...
    西红柿君呐阅读 116评论 0 0
  • 一、算术运算符 算术运算使用的符号,用于执行两个变量或值的算术运算。 二、递增和递减运算符 如果需要反复给数字变量...
    testleaf阅读 181评论 0 4
  • 运算符(operator)也被称为操作符,是用于实现赋值、比较和执行算数运算等功能的符号。 JavaScript中...
    Imkata阅读 139评论 0 0
  • 在 JavaScript 语言中,运算符主要用于执行程序代码运算,针对一个以上的操作数项目来进行运算。运算符大家应...
    暖A暖阅读 257评论 0 0
  • 在 JavaScript 语言中,运算符主要用于执行程序代码运算,针对一个以上的操作数项目来进行运算。运算符大家应...
    前白阅读 291评论 0 1