Js运算符(操作符)
算数运算符
a = 1 + 1 // 2
a = 10 - 5 // 5
a = 10 / 5 // 2
a = 10 / 0 // js中除以0不会报错,结果是Infinity
a = 2*2 // 4
a = 2**2 //
a = 10 % 4 // 取余,2
js中算数运算,除了字符串的加法,会自动将非数值转换为int进行计算,不像其他语言会报错
a = 10 + true // 11
a = 10 - "3" // 7
a = 5 + null // 5
a = 5 - undefined // NaN
字符串的加法,会将非字符串的值转换为字符串,进行字符串拼接
a = "1" + a // "1a"
a = "1" + 1 // "11"
a = "1" + null // 1null
利用算数运算隐式类型转换的特性,也可以用于类型转换,比如
true +'',使用值与空字符串相加,结果会将true转换成字符串的true
赋值运算符
=用来将一个值赋值给一个变量
let a
a = 10 // 将右边的值,赋值给左边变量
let b = a // 将a赋值给b,一个变量只有在左边的时候才是变量,在右边的时候就是值
赋值运算
// 大部分运算符不会改变变量的值,赋值运算符除外
a = 10
a + 1 // a+1的结果是11,但是a还是10,结果没有赋值
a += 1 // a的结果是11,等价于 a = a + 1, /= 、*= 等等原理一样
??=空赋值
只有当变量的值是null或undefined的时候,才会进行赋值操作
let a
a ??= 1 // a没有值,将1赋值给a
console.log(a) // 1
let b = 10
b ??= 2 // b已经有值了,所以不会将2赋值给b
console.log(b) // 2
一元正负
let a = 10
// 正号:不会改变数值的符号
a = +a // 10
// 负号:可以对数值进行符号位取反
let b = 10
b = -b // -10
a = -a // -10
// 当对非数值类型进行正负运算时,会先将其转化为数值然后再运算
let c = "10"
c = +c // int 10,等价于b=Number(c),也可以使用一元的+转换类型
c = -c // int -10
自增和自减
自增
自增分为前自增(变量++)和后自增(++变量)
// 前自增
let a = 10
console.log(a++) // 10
console.log(a) // 11
// 后自增
let b = 20
console.log(++b) // 21
console.log(b) // 21
// 前后自增都会使原变量的值增加1,区别在于返回值不同
// 前自增表达式的返回值是自增前的值,后自增的返回值是自增后的值
自减
自减也分为前自减和后自减,原理与自增一致
let c = 10
console.log(c--) // 10
console.log(c) // 9
let d = 10
console.log(--d) // 9
console.log(d) // 9
逻辑运算符
逻辑非!
!可以对一个值进行非运算,可以对一个布尔值进行取反操作,如果对一个非布尔值进行取反,会先将其转化为布尔值再进行取反,可以利用该特定将其他类型转换为布尔值
let result
result = !0 // true
逻辑与&&
与运算如果所有的表达式都是为true,则返回true,否则返回false
与运算是短路的,如果有值为false,则直接返回false,不会向后执行
let result
result = true && true // true
result = true && false // false
result = true && alert(1) // alert会执行
result = false && alert(1) // alert不会值
对于非布尔值的运算,会将其转化为布尔值进行运算,但是最终返回不是布尔,会返回原值
如果有值为false,则直接false的值,如果值都为true,则返回最后一个值
let result
result = 1 && 2 && 3 // 3
result = 1 && 0 && 2 // 0
逻辑或||
当 ||运算的时候左右有true的值,则返回true,否则false
或运算也是短路的,如果找到true则直接返回,不会向后运算
对于非布尔值的运算,会转换为布尔值然后运算,但是最终也会返回原值,如果第一个是false返回第二个值
let result
result = true || false // true
result = false || false // false
result = 1 || 2 // 1
result = 0 || 2 // 2
result = 1 || alert(1) // 不会会执行alert
result = 0 || alert(1) // 会执行alert
关系运算符
检查两个值之间的关系是否成立,成立返回true,不成立返回false
let result
result = 5 > 5 // false
result = 5 >=5 // true
result = 5 <= 5 // true
// 当对非数值进行关系运算时,会先转为为数值再比较
result = "1" > false // true
result = 5 < "10" // true
// 当关系运算符两端是两个字符串,不会将字符串转换数值,而是逐位比较自费的Unicode编码
result = "a" < "b" // true
result = "12" > "2" // false ,即使两个字符串都是数值,也不会转换数值运算
result = +"12" > "2" // true 可以使用一元运算将一个值转换为数值,则会进行数值运算
相等运算符
==相等运算符,用来比较两个值是否相等,相等返回true,否则false
- 如果两个值是不同类型时,相等运算符会将他们转换为同类型(通常是数值)再比较
- null和undefined进行相等比较时返回true
- NaN不和任何值相等,包括他自身
===全等运算符都是用来比较两个值是否相等 如果两个值是不同类型,不会进行类型转换,如果两个值类型不同,则直接返回false
let result
// 相等运算
result = 1 == 2 // false
result = "1" == 1 // true
result = null == undefined // true
// 全等运算
result = "1" === 1 // false
result = 2 === 2 // true
result = null === undefined // false,undefined和null相等,但是不全等
!=:比较两个值是否不相等,会自动进行类型转换
!==:比较两个值是否不全等,不会自动进行类型转换
result = 1 != 1 // false
result = 1 != "1" // false
result = 1 !== "1" // true
条件运算符(三元运算符)
条件表达式?表达式1:表达式2
执行顺序:
- 先对表达式进行一个求值判断,如果结果为true,则执行表达式1,如果结果为false,则执行表达式2
let a = 10
let b = 20
a > b ? alert("a") : alert("b")
let max = a > b ? a : b // 如果a大于b,则max=a,否则等于b
运算符中()拥有最高优先级,如果需要优先运算,可以使用()把表达式包裹起来
Js运算符(操作符)的更多相关文章
- JS运算符
JS运算符: 使用的运算符的时候不需要声明变量,运算符非变量:1.算术运算符 + - * / % (%为取余数运算符) (自增运算符++) (自减运算符 --) + 运算符作用:1.数值相加 2.字符 ...
- sizeof既是关键字,又是运算符(操作符),但不是函数!
sizeof是关键字吗 sizeof是关键字,这一点毋庸置疑.你不能将sizeof定义为任何标识符.查看C语言标准文档里的说明: sizeof是运算符(操作符)吗 C语言中,sizeof是运算符(操作 ...
- js 运算符优先级
在看jquery源码,仔细看入口函数的时候,有点懵了.看到与或.多重三目,傻傻的分不清,就代码仔细的区分下运算符优先级,以前都是呼呼的飘过.看来任何一个细节都不能忽略,不然效率极低.. !functi ...
- js运算符单竖杠“|”的用法和作用及js数据处理
js运算符单竖杠“|”的作用 很多朋友都对双竖杠“||”,了如指掌,因为这个经常用到.但是大家知道单竖杠吗?今天有个网友QQ问我,我的 javascript实用技巧,js小知识 , 这篇文章里面,js ...
- js值类型转换(boolean/String/number),js运算符,if条件,循环结构,函数,三种弹出框
js值类型转换 number | string | boolean boolean类型转换 num = 0; var b1 = Boolean(num); console.log(b1) 转化为数字类 ...
- js运算符的一些特殊应用
作者: 小文 来源: http://www.cnblogs.com/daysme/ 时间: 2017/3/2 17:21:03 本文集合了了js运算符的一些特殊应用. js位运行符的运用. js运算符 ...
- js课程 2-6 js如何进行类型转换及js运算符有哪些
js课程 2-6 js如何进行类型转换及js运算符有哪些 一.总结 一句话总结: 1.所有类型->布尔类型(为假的情况)有哪些(6种)? 1)字符串('')2)整型(0)3)浮点型(0.0)4) ...
- 【Java】Operator 运算符/操作符
Operator 运算符/操作符 什么是操作符? 一个表示特定的数学或逻辑操作的符号 算术运算符 加 + 减 - 乘 * 除 / 取模 % 前置自运算 ++ a .--b 后置自运算 a++ .b-- ...
- js 运算符的执行顺序
js 运算符的执行顺序 js 运算符优先级 Operator Precedence 下表从最高(21)到最低(1)优先顺序排列 left-to-right 从左到右 / 先左后右 right-to-l ...
- js运算符逻辑!和instanceof的优先级
写js时间长了,运算符优先级很可能自然而然的就形成习惯了,也不需要特别注意优先级的问题. 至少到目前为止,我也没有真正了解过js当中所有运算符的具体优先级.也没有出过什么重大的问题. 但是直到今天,在 ...
随机推荐
- 使用 Doxygen 来生成 Box2d 的 API 文档
对于 Doxygen 以前只听别人说过,而现在使用它也是一个偶然,缘分吧.前两天看 box2d 的官方 sdk 中,发现他有用户手册却没有说明,只是留下了一个 Doxygen 的文件.事情告一段落,然 ...
- electron安装成功记录
1.登录官网查看当前最新版本对应的node,注意这里不要看php那个汉化的,他那个是老版本的,node对不上 2.nvm安装一个新的node 3.使用cnpm安装(npm安装还是报错了,记得删node ...
- 记hashmap
hashmap是map接口的一个实现类,在同步的情况下hashmap的性能是比较好的 hashmap就是一个kv键值对的集合,将数值散列均匀的存储在哈希表中.插入方法为map.put(k,v),读取方 ...
- Python和RPA网页自动化-处理alert弹框
以百度为例,分别使用python和RPA自动化完成以下步骤:设置->搜索设置->保存设置->确定 1.python代码如下 注意:[已经记录下您的使用偏好]弹框是无法捕获网页源代码的 ...
- 【Redis】03 Redis 数据类型、相关补充、常用命令
redis的数据类型 1,概述 使用Redis进行应用设计和开发的一个核心概念是数据类型. 与关系数据库不同,在Redis中不存在需要我们担心的表, 在使用Redis进行应用设计和开发时,我们首先应该 ...
- 【TypeScript】02 面向对象
[联合类型] 联合类型(Union Types)可以通过管道(|)将变量设置多种类型,赋值时可以根据设置的类型来赋值. 注意:只能赋值指定的类型,如果赋值其它类型就会报错. var val:strin ...
- 基于 ChatGPT 的聊天软件合集打包分享
「基于 ChatGPT 的聊天软件合集打包」 链接:https://pan.quark.cn/s/ef1f5e9c48e4 BotGem(原名AMA) 官网:https://botgem.com/ ...
- 【转载】 SUN RPC的传输层实现机制 —— rpcbind(nfs文件系统中的rpc)
原文地址: https://blog.csdn.net/dingguo815/article/details/5421675 ===================================== ...
- Tensorflow1.14中placeholder.shape和tf.shape(placeholder)的区别
最近在看TensorFlow的代码,还是1.14版本的TensorFlow的,代码难度确实比pytorch的难上不是多少倍,pytorch的代码看一遍基本能看懂个差不多,TensorFlow的代码看一 ...
- 聊一聊 Netty 数据搬运工 ByteBuf 体系的设计与实现
本文基于 Netty 4.1.56.Final 版本进行讨论 时光芿苒,岁月如梭,好久没有给大家更新 Netty 相关的文章了,在断更 Netty 的这段日子里,笔者一直在持续更新 Linux 内存管 ...