首页 > 其他分享 >Js运算符(操作符)

Js运算符(操作符)

时间:2024-09-30 13:23:17浏览次数:8  
标签:10 false Js 运算符 操作符 result let true

算数运算符

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

运算符优先级

运算符中()拥有最高优先级,如果需要优先运算,可以使用()把表达式包裹起来

标签:10,false,Js,运算符,操作符,result,let,true
From: https://www.cnblogs.com/Mickey-7/p/18441656

相关文章

  • nodejs koa 用knex.js链接mysql数据库,进行数据增删改查
    1、knex.js安装npminstallknex官方Installation|Knex.js中文文档|Knex.js中文网2、进行数据库链接constknex=require('knex')({client:'mysql2',connection:{host:'127.0.0.1',//地址user:'root',//账号......
  • jsp“小饰界”线上饰品商城的设计与实现u39l6(程序+源码+数据库+调试部署+开发环境)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表用户,商品分类,商品信息,活动商品,知识普及开题报告内容一、项目背景与意义随着互联网技术的飞速发展,电子商务已成为现代商业的重要组成部分。饰品作为时尚消......
  • jsp“海洋生态环境保护宣传”网站设计与实现f87t4--程序+源码+数据库+调试部署+开发环
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表用户,海洋知识,知识分类,视频专区,活动报名,报名信息,截止报名技术要求:开发语言:JSP前端使用:HTML5,CSS,JSP动态网页技术后端使用SpringBoot,Spring技术主数据......
  • jsp“轻车熟路”旅游线路规划系统ql7mh--(程序+源码+数据库+调试部署+开发环境)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表游客,游记分享,旅游景点,旅游攻略,地区信息,路线分类,路线规划,景点特产,景点美食技术要求:开发语言:JSP前端使用:HTML5,CSS,JSP动态网页技术后端使用SpringBoo......
  • nodejs
    IntroductionForNodejsbaseonv8engine,andsignalthread,andasynconousI/O.基于v8,性能出色单线程,没有线程开销,没有多线程相关的复杂的问题(锁,池等,thesourceofbug.),隐藏了,其实node自己本身底层的实现有多线程池,只是上层不必考虑.异步I/O,不会浪费cpu等......
  • Vue.js组件开发详解
    Vue.js组件开发详解Vue.js是一个用于构建用户界面的渐进式框架,其核心思想是通过数据驱动视图的变化,同时提供了一系列强大的工具来帮助开发者高效地开发复杂的单页应用。在Vue.js中,组件是构建复杂应用的基本单元,通过组件化开发,我们可以将应用拆分成可复用的、独立的模块,......
  • 《循序渐进Vue.js 3.x前端开发实践》:前端开发者的必备指南
    文章目录......
  • JS实现String.Format
    js实现string.format功能<scripttype="text/javascript">varerrorHtml="<atitle=\"{1}\"href=\"#\"onclick=\"\"class=\"ml-5\"style=\"text-decoration:none;color:#FF3C3......
  • 高点摄像山火烟雾检测数据集 共2890张图像,分辨率1920×1080,标注采用json格式,标注了每
    高点摄像山火烟雾检测数据集(并按照低、中详细标注烟雾浓度)。主要针对初期山火,任何野火检测系统的最重要目标是在火势扩大之前及时检测到火灾。在初期阶段,野火由非火焰性的燃烧烟雾组成,热量相对较低。在这个阶段识别火灾能够提供最佳的抑制机会。在这个阶段通常看不到火焰;因此,任......
  • nodejs学习
    nodejs中的v8引擎模块一、promise钩子模块;二、垃圾回收模块;1、promise钩子包括:(1)onInit(callback)在promise创建时调用;(2)onSettled(callback)在fulfilled或rejected时调用;(3)onBefore(callback)在promise继续执行之前调用的回调;(4)onAfter(callback)在promise继续执行之后调......