JavaScript运算符

6 篇文章 0 订阅
5 篇文章 0 订阅

一元运算符

一元运算符只需要一个操作数
+ 正号 不会对数字产生任何影响
- 负号 负号可以对数字进行符号的取

对于非Number类型的值,它会先将其转换为Number,然后再运算
可以对一个其他的数据类型使用+ 来将其转换为number,它的原理和Number()函数一样

var result = +null;
console.log("result = "+result);
console.log(typeof result);  

运行结果:
这里写图片描述

自增和自减

自增++

通过自增可以使变量在自身的基础上增加1
对一个变量自增以后,原变量的值会立即自增1
自增分为两种:后++ 和 前++
无论是a++ 还是++a 都会立即使原变量的值自增1
不同的是a++ 和 ++a的值不同
a++的值等于原变量的值(自增前的值)
++a的值等于新值(自增后的值)

var d = 20;
var result = d++ + ++d + d;//20+22+22
console.log("result = "+result);

这里写图片描述

var d = 20;
//d++ = 20;
d = d++;
/*可分解成:
var e = d++;
d = e;
 */
console.log("d= "+d);

这里写图片描述

逻辑运算符

1、与 &&(类比爱情)

可以对符号两侧的值进行与运算并返回结果

运算规则:

两个值中 只要有一个值为false就返回false
只有两个值都为true时 才会返回true
js中的“与”属于短路的与 如果第一个值为false 则不会看第二个值

2、或 || (类比亲情)

可以对符号两侧的值进行或运算 并返回结果

运算规则:

两个值中只要有一个true 就返回true
如果两个之都为false 才返回false
js中的“或” 属于短路的或
如果第一个值为true 则不会检查第二个值

3、非!

!可以用来对一个值进行非运算
所谓非运算 就是指对一个布尔值进行取反操作
true变false false变true
如果对非布尔值进行运算 则会将其转换为布尔值 再取反
所以我们可以利用该特点 来将一个其他的数据类型转换为布尔值
可以为一个任意数据类型取两次反,来将其转换为布尔值
原理和Boolean()函数一样

var b = 10;
b = !b;
console.log("b = "+b);
console.log(typeof b);

运行结果:

这里写图片描述

对于非布尔值进行与或运算时,会先将其转换为布尔值,然后再运算,并且返回原值

与运算:

  如果第一个值为true 则必然返回第二个值
  如果第一个值为false 则直接返回第一个值
  //true && true
  var result = 1 && 2;
  console.log("result = "+result);

运算结果:

这里写图片描述

或运算:

如果第一个值为true,则直接返回第一个值
如果第一个值为false 则返回第二个值
  //如果第一个值为true,则直接返回第一个值
  result = 1 || 2;
  console.log("result = "+result);
  result = 2 || NaN;
  console.log("result = "+result);
  result = 2 || 0;
  console.log("result = "+result);
//如果第一个值为false,则直接返回第二个值
  result = NaN || 1;
  console.log("result = "+result);
  result = NaN || 0;
  console.log("result = "+result);
  result = "" || "hello";
  console.log("result = "+result);
  result = -1 || "你好";
  console.log("result = "+result);

这里写图片描述

关系运算符

对于非数值进行比较时 会将其转换为数字然后再比较
任何值和NaN做任何比较都是false
如果符号两侧的值都是字符串时 不会将其转换为数字进行比较 而会分别比较字符串中字符集的unicode编码

//任何值和NaN做任何比较都是false
console.log(10 <= "hello");//false
console.log(true>false);//true

//比较两个字符串时 比较的是unicode编码
console.log("1"<"5");//true
console.log("11"<"5")//true

//比较字符编码时时一位一位进行比较
//如果两位一样,则比较下一位,所以借用它来对英文进行排序
//比较中文没有意义(unicode编码根据康熙词典排序的)
console.log("abc"<"b");//true

条件运算符

条件运算符也叫三元运算符
语法:

条件表达式?语句1:语句2

执行的流程:

条件运算符在执行时 首先对条件表达式进行求值
如果该值为true,则执行语句1,并返回执行结果
如果该值为false 则执行语句2 并返回执行结果
如果条件表达式的求值结果是一个非布尔值
会将其转换为布尔值然后再运算

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值