条件判断篇
输入>>>
输出<<<
==的机制
使用==会如果是两种类型的变量会先做转换,
比如
>>>1 == ‘1’
<<< true
如果是一个对象会发生什么?
是否会使用valueOf完成对象的转换?
我们来做一个实验
var a = {a:1,valueOf:function(){return this.a}}
console.log(1==a)
console.log(1===a)
这里输出true false
在使用==做对象判断时确实会使用valueOf转换
***如果没有valueOf修改toString也是可以的
由上引申出的一个思考
如果没有valueOf 只有toString然后返回一个非原始值
再使用 1==a 会发生什么
var a = {a:1,toString:function(){return /1234/}}
console.log(1==a)
报错了
TypeError
***说明确实使用了toString然后因为不是原始值无法转为字符串所以报错了
第二个思考如果返回字符串1是否会再转换一次
var a = {a:1,toString:function(){return '1'}}
console.log(1==a)
true
***其实等价于
1=='1'
等价于
1==1
true会转成0
false会转成1
就是说
>>> 1 == true; ‘1’==true;
<<< true
===的机制
就是不做转换操作的==。
注意!几个会出错的转换
>>> !![]
<<< true
>>> !!{}
<<< true
虽然数组对象是空
但他们其实代表true
使用if的时候要注意
在使用小于大于时,优先进行值的转换而不是字符串
在使用"+"时我们知道优先进行的是字符串的转换,只有包含有一个字符串就会转成String然后拼接。
在使用小于大于时,同上但是优先进行值的转换。
看实例
"1" < 2
输出true
等价于 1 < 2
"5" < "3"
true
没事别搞字符串的比较脑壳疼
"abc" < 4
false
相当于 NaN < 4
当一个操作数是NaN的时候就返回false
in运算符与Python的区别
python代码
a = [7,8,9]
print(7 in a)
#输出 True
a = {'a':1}
print('a' in a)
#输出 True
javascript代码
var a = [7,8,9]
console.log(7 in a)
//输出 false
a = {'a':1}
console.log('a' in a)
//输出 true
a = {'1':'abc'}
console.log(1 in a)
//输出 true
a = [7,8,9]
console.log('2' in a)
//输出 true
console.log(2 in a)
//输出 true
in 在javascript中指的是对象的属性
数组也是一个一个对象
如果数组a = [3,4,5]
其实相当于
{
"0":3,
"1":4,
"2":5,
………………
}
所以3 in a 是 false
而2 in a 是 true做了转换
2->"2"
a && b ;a || b
var a = {x:1}
console.log( a && a.x )
//条件判断 这个是true这是肯定的
//但其实
a && a.x 返回的是 a.x也就是1
也就是说&& || 我们可以拿来复制
比如有这么一个场景
ab都有可能有值,优先用a,a没值就用b的
那么可以这样
var value = a||b
或者
if(a)
{value=a}
else
{value=b}这样写就比较长