js 各种逻辑坑

1. [1<2<3,3<2<1]:

  返回的是[true,true].原因是1<2<3等同于(1<2)<3就是 true<3,在比较的时候true或者false就么默认转化为数字1或0,最后就是[1<3,0<1],故是[true,true]

2.var a=1.0-0.9;  if(a==0.1){ console.log(true)}else{console.log(false)}  var b=0.8-0.7;if(a==b){console.log(true)}else{console.log(false)}

    返回的是  false false  ,这是由于 js小数运算会丢失精度,

3.var x=30; function test(){console.log(x); var x=10;console.log(x);x=20;function x(){} console.log(x)} test()

  返回的是ƒ x(){}  10   20

4. var a={n:1};var b=a; a.x=a={n:2}; console.log(a.x);console.log(b.x)

  返回的是 undefined   {n: 2};原因是  js的赋值运算顺序永远都是从右往左的,不过由于“.”是优先级最高的运算符,所以这行代码先“计算”了a.x,这时候发生了这个事情——a指向的对象{n:1}新增了属性x(虽然这个x是undefined的),由于b跟a一样是指向对象A的,要表示A的x属性除了用a.x,自然也可以使用b.x来表示了,接着,依循“从右往左”的赋值运算顺序先执行 a={n:2} ,这时候,a指向的对象发生了改变,变成了新对象{n:2}(我们称为对象B),

接着继续执行 a.x=a,很多人会认为这里是“对象B也新增了一个属性x,并指向对象B自己”但实际上并非如此,由于( .  运算符最先计算)一开始js已经先计算了a.x,便已经解析了这个a.x是对象A的x,所以在同一条公式的情况下再回来给a.x赋值,也不会说重新解析这个a.x为对象B的x。所以 a.x=a 应理解为对象A的属性x指向了对象B:

那么这时候结果就显而易见了。当console.log(a.x)的时候,a是指向对象B的,但对象B没有属性x。没关系,当查找一个对象的属性时,JavaScript 会向上遍历原型链,直到找到给定名称的属性为止。但当查找到达原型链的顶部 - 也就是 Object.prototype - 仍然没有找到指定的属性B.prototype.x,自然也就输出undefined;

转载于:https://www.cnblogs.com/hongchenzimo/p/11077069.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值