JavaScript数据类型和变量学习小记
今天,天气不晴朗。
闲来无事随便看了看廖大的JavaScript教程,本人愚钝,作此随笔摘录几点以便日后学习。
比较运算符
先看个简单例子:
在上图中我们很容易看出对于JS来说“==”和“===”并不相同,那么区别在何处呢?我们接着往下看。
原来是这样的:
JavaScript在设计时,有两种比较运算符:
第一种是
==
比较,它会自动转换数据类型再比较,很多时候,会得到非常诡异的结果;第二种是
===
比较,它不会自动转换数据类型,如果数据类型不一致,返回false
,如果一致,再比较。
由于JavaScript这个设计缺陷,不要使用==
比较,始终坚持使用===
比较。【切记切记!!】
同样的,浮点型数据的相等比较同样需要注意,比如:
why?因为:
这样就很容易理解了。
当然,这并不是JavaScript的设计缺陷,而是计算机的缺陷,毕竟图样嘿嘿嘿。
浮点数在运算过程中会产生误差,因为计算机无法精确表示无限循环小数。那么我们该如何比较两个浮点数?
廖老师在教程里告诉我:
要比较两个浮点数是否相等,只能计算它们之差的绝对值,看是否小于某个阈值:
Math.abs(1 / 3 - (1 - 2 / 3)) < 0.0000001; // true
这个阀值并不能过于精确。
看来做人也要向计算机学习,是不能斤斤计较的啊。