Javascript运算符——算术运算符、三元运算符、自增 与 自减、比较运算符、逻辑运算符、= 与== 与 === 的区别

2024-04-13 01:08

本文主要是介绍Javascript运算符——算术运算符、三元运算符、自增 与 自减、比较运算符、逻辑运算符、= 与== 与 === 的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1、算术运算符

2、三元运算符

3、自增 自减 / 递增 递减

4、比较运算符

5、逻辑运算符

6、双非 !! 作用讲解

运算符优先级

= 与== 与 === 的区别 


1、算术运算符


1. 加号 +(可用于字符串拼接)

加号两侧同时为数字,进行加法运算
加号两侧任何一侧为字符串,表示字符串拼接        (符号两侧要用空格隔开)

2.减号 -         3.乘号 *         4.除号 /        5.取余 %(只有+号会进行字符串的拼接,其余不会)

在进行减 乘 除 取余运算时:

符号两侧同时为数字进行对应的算术运算,若其中有一侧为非数字,则运算时会把该侧转换为数字,转换成功,进行对应的算术运算,转换失败,得到NaN(Not a Number非数字)    

  <script>/*+ 加- 减* 乘/ 除% 取余数*/console.log(2 + 3);console.log(2 - 3);console.log(2 * 3);console.log(2 / 3);console.log(3 % 2);console.log(4 % 2); //余数0</script>
  1. +=  加等
  2. -= 减等
  3. *= 乘等
  4. /= 除等
  5. %= 
 var a = 10;a = a + 2;a += 2; // 输出12 和a=a+3结果相等,加等 
//其他几个用法相同

 字符拼接问题:

   console.log(2 + 4 + "=" + 6); //6=6console.log(4 + "=" + 3 + 1); //4=31 从左往右依次运算,先乘除,后加减,有括号先算括号内的console.log(4 + "=" + (3 + 1)); //4=4

2、三元运算符

语法: 条件        ?语句1        :语句2;

条件成立执行语句1,条件不成立执行语句2

<script>// 举例:var a = prompt('请输入数字'),b = prompt('请输入数字');a > b//条件? document.write(a + b)//语句1: document.write(b + a);//语句2//举例var num = prompt("请输入一个数字", 0);num % 2 == 0 ? console.log(num + "是偶数") : console.log(num + "是奇数");</script>

3、自增 自减 / 递增 递减

递增(++)

递减(- -)

放在变量前面时,我们称为前置递增(递减)运算符

放在变量后面时,我们称为后置递增(递减)运算符

注意:递增和递减运算符必须和变量配合使用。

①前置递增运算符

++num num = num + 1

使用口诀:先自加,后返回值

var num = 10;
alert (++num + 10); // 21

②后置递增运算符

num ++ num = num +1

使用口诀:先返回原值,后自加

var num = 10;
alert(10 + num++); // 20

③小结

  • 前置递增和后置递增运算符可以简化代码的编写,让变量的值 + 1 比以前写法更简单
  • 单独使用时,运行结果相同,与其他代码联用时,执行结果会不同
  • 开发时,大多使用后置递增/减,并且代码独占一行

4、比较运算符

 除恒等外,其他比较过程都会进行类型转换 (但两侧同为字符串时不能自行完成类型转换

  • 大于>
  • 小于<
  • 小于等于<=
  • 大于等于>=
  • 等于==
  • 不等于!=
  • 恒等===

     返回布尔值

    console.log(5 > 8); //falseconsole.log(5 < 8); //trueconsole.log(5 >= 8); //false console.log(5 <= 8); //trueconsole.log(5 == 5); //trueconsole.log(5 == "5"); //true 比较过程中也会进行类型转换console.log(5 === "5"); //false恒等,值和类型都要相等,不会进行类型转换console.log(1 == true); //trueconsole.log(null == undefined); //trueconsole.log(null == 0); //falseconsole.log(0.1 + 0.2 == 0.3); //false

5、逻辑运算符

  •  逻辑与 &&   符号两侧同时为真,才为真,其他情况均为假
  • 逻辑或 ||   符号两侧同时为假才为假,其他情况均为真
  • 逻辑非 !非真即假 非假即真
  • !!双等号可进行类型转换  两个!!就可以将变量或属性转化为对应布尔值

6、双非 !! 作用讲解

javascript中的!!是逻辑"非非",即是在逻辑“非”的基础上再"非"一次。通过!或!!可以将很多类型转换成bool类型,再做其它判断。

使用javascript时,有时会在变量前面加上两个感叹号,这样做表示什么含义呢?Javascript中,!表示运算符“非”,如果变量不是布尔类型,会将变量自动转化为布尔类型,再取非,那么用两个!!就可以将变量转化为对应布尔值。

详情参考http://t.csdn.cn/0VkoT

    //逻辑与&&  符号两侧同时为真,才为真,其他情况均为假//短路console.log(true && true); //trueconsole.log(true && false); //falseconsole.log(false && false); //false//逻辑或||  符号两侧同时为假才为假,其他情况均为真console.log(true || true); //trueconsole.log(true || false); //trueconsole.log(false || false); //false// 逻辑非 ! 非真即假 非假即真console.log(!true); //falseconsole.log(!false); //true

运算符优先级

优先级运算符顺序
1小括号()
2一元运算符++ - - !
3算数运算符先 * / % 后 + - (先乘除后加减)
4关系运算符> >= < <
5相等运算符==、   !=  、  ===、   !==
6逻辑运算符先  &&  后  ||
7赋值运算符=(赋值运算符优先级最低)
 

= 与== 与 === 的区别 

=表示赋值

== 表示相等 (值相等)
===表示恒等(类型和值都要相等)
js在比较的时候如果是 == 会先做类型转换,再判断值得大小,如果是===类型和值必须都相等。

这篇关于Javascript运算符——算术运算符、三元运算符、自增 与 自减、比较运算符、逻辑运算符、= 与== 与 === 的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/898743

相关文章

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

Java docx4j高效处理Word文档的实战指南

《Javadocx4j高效处理Word文档的实战指南》对于需要在Java应用程序中生成、修改或处理Word文档的开发者来说,docx4j是一个强大而专业的选择,下面我们就来看看docx4j的具体使用... 目录引言一、环境准备与基础配置1.1 Maven依赖配置1.2 初始化测试类二、增强版文档操作示例2.

一文详解如何使用Java获取PDF页面信息

《一文详解如何使用Java获取PDF页面信息》了解PDF页面属性是我们在处理文档、内容提取、打印设置或页面重组等任务时不可或缺的一环,下面我们就来看看如何使用Java语言获取这些信息吧... 目录引言一、安装和引入PDF处理库引入依赖二、获取 PDF 页数三、获取页面尺寸(宽高)四、获取页面旋转角度五、判断

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

C++中全局变量和局部变量的区别

《C++中全局变量和局部变量的区别》本文主要介绍了C++中全局变量和局部变量的区别,全局变量和局部变量在作用域和生命周期上有显著的区别,下面就来介绍一下,感兴趣的可以了解一下... 目录一、全局变量定义生命周期存储位置代码示例输出二、局部变量定义生命周期存储位置代码示例输出三、全局变量和局部变量的区别作用域

JAVA中安装多个JDK的方法

《JAVA中安装多个JDK的方法》文章介绍了在Windows系统上安装多个JDK版本的方法,包括下载、安装路径修改、环境变量配置(JAVA_HOME和Path),并说明如何通过调整JAVA_HOME在... 首先去oracle官网下载好两个版本不同的jdk(需要登录Oracle账号,没有可以免费注册)下载完

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

Java中Integer128陷阱

《Java中Integer128陷阱》本文主要介绍了Java中Integer与int的区别及装箱拆箱机制,重点指出-128至127范围内的Integer值会复用缓存对象,导致==比较结果为true,下... 目录一、Integer和int的联系1.1 Integer和int的区别1.2 Integer和in

SpringSecurity整合redission序列化问题小结(最新整理)

《SpringSecurity整合redission序列化问题小结(最新整理)》文章详解SpringSecurity整合Redisson时的序列化问题,指出需排除官方Jackson依赖,通过自定义反序... 目录1. 前言2. Redission配置2.1 RedissonProperties2.2 Red