发表于: 2019-11-09 23:27:26
1 1072
今天完成的事:
完成任务11
明天计划的事:
学习微信公众号
遇到的问题:
暂无
收获:
学习了几个js中常用小技巧
1. 类型强制转换
1.1 string强制转换为数字
可以用*1
来转化为数字(实际上是调用.valueOf
方法)
然后使用Number.isNaN
来判断是否为NaN
,或者使用 a !== a
来判断是否为NaN
,因为 NaN !== NaN
常用:也可以使用+
来转化字符串为数字
1.2 object强制转化为string
可以使用 字符串+Object
的方式来转化对象为字符串(实际上是调用 .toString()
方法)
当然也可以覆盖对象的toString
和valueOf
方法来自定义对象的类型转换:
《Effective JavaScript》P11:当+
用在连接字符串时,当一个对象既有toString
方法又有valueOf
方法时候,JS通过盲目使用valueOf
方法来解决这种含糊。
对象通过valueOf
方法强制转换为数字,通过toString
方法强制转换为字符串
1.3 使用Boolean过滤数组中的所有假值
我们知道JS中有一些假值:false
,null
,0
,""
,undefined
,NaN
,怎样把数组中的假值快速过滤呢,可以使用Boolean构造函数来进行一次转换
1.4 双位运算符 ~~
可以使用双位操作符来替代正数的 Math.floor( )
,替代负数的Math.ceil( )
。双否定位操作符的优势在于它执行相同的操作运行速度更快。
不过要注意,对正数来说 ~~
运算结果与 Math.floor( )
运算结果相同,而对于负数来说与Math.ceil( )
的运算结果相同:
1.5 短路运算符
我们知道逻辑与&&
与逻辑或||
是短路运算符,短路运算符就是从左到右的运算中前者满足要求,就不再执行后者了;
可以理解为:
&&
为取假运算,从左到右依次判断,如果遇到一个假值,就返回假值,以后不再执行,否则返回最后一个真值||
为取真运算,从左到右依次判断,如果遇到一个真值,就返回真值,以后不再执行,否则返回最后一个假值- let param1 = expr1 && expr2let param2 = expr1 || expr2
运算符 | 示例 | 说明 |
---|---|---|
&& | expr1&&expr2 | 如果expr1 能转换成false则返回expr1,否则返回expr2. 因此, 在Boolean环境中使用时, 两个操作结果都为true时返回true,否则返回false. |
|| | expr1||expr2 | 如果expr1能转换成true则返回expr1,否则返回expr2. 因此,在boolean环境(在if的条件判断中)中使用时, 二者操作结果中只要有一个为true,返回true;二者操作结果都为false时返回false. |
! | !expr | 如果单个表达式能转换为true的话返回false,否则返回true. |
因此可以用来做很多有意思的事,比如给变量赋初值:
如果variable1是真值就直接返回了,后面短路就不会被返回了,如果为假值,则会返回后面的foo
。
也可以用来进行简单的判断,取代冗长的if
语句:
如果param
如果为真值则返回param.prop
属性,否则返回param
这个假值,这样在某些地方防止param
为undefined
的时候还取其属性造成报错。
1.6 取整 | 0
对一个数字| 0
可以取整,负数也同样适用,num | 0
1.7 判断奇偶数 & 1
对一个数字& 1
可以判断奇偶数,负数也同样适用,num & 1
评论