js表达式运算--细节易错(总结)
2016-01-18 16:57
543 查看
我们在使用js的过程中,会经常进行js表达式运算,但是很多时候,由于js的语言特点,有些计算结果会让我们大吃一惊。
很多时候的结果并不是我们预期的,或者又说,有时候明明已经出错,但是偏偏得出了正确的结果。
js在运算的时候,如果两个运算式子不同类型,那么就会进行隐式强制类型转换
这样的js运算细节有很多,总结下目前所了解的:
第1组
解决方案:扩大倍数,变成整数运算,再除以扩大倍数
第2组
原理:整数(浮点)数字和字符数字,相加,总是朝着字符串的方向装换
第3组
原理:true为1,false为0
第4组
解释:NaN不等于其自身原则
知识:
===在类型+值一样,判断会正确
==在类型一样,判断会正确。其余情况结果不可信,因为存在隐式类型转换
第5组
解释:逗号表达式,连续运算,一般最后一个数会作为表达式的结果
待续…
很多时候的结果并不是我们预期的,或者又说,有时候明明已经出错,但是偏偏得出了正确的结果。
js在运算的时候,如果两个运算式子不同类型,那么就会进行隐式强制类型转换
这样的js运算细节有很多,总结下目前所了解的:
第1组
0.1+0.2; //0.30000000000000001 (0.1+0.2)+0.3; //0.6000000000000001 0.1+(0.2+0.3); //0.6
解决方案:扩大倍数,变成整数运算,再除以扩大倍数
第2组
1 + "2"; //12 "2" + 1; //21 1 + 2 + "3"; //33 1 + "3" + 2; //132
原理:整数(浮点)数字和字符数字,相加,总是朝着字符串的方向装换
第3组
4 + true; //5 4 + false; //4
原理:true为1,false为0
第4组
NaN === NaN; //false NaN !== NaN; //true undefined == null; //true undefined === null; //false
解释:NaN不等于其自身原则
知识:
===在类型+值一样,判断会正确
==在类型一样,判断会正确。其余情况结果不可信,因为存在隐式类型转换
第5组
var a = (1,2,3,4); //a = 4 a = 1,2,3,4; //a = 1 var b = (a = 1,2,3,4); //a = 1,b = 4 var b = ( a = (1,2,3,4) ); //a = 4,b = 4 //错误写法 var a = 1, 2, 3, 4; //Uncaught SyntaxError: Unexpected number(…); //帮助理解下 var b = ( var a = 1, 2, 3, 4 ); //等式左右都有var...
解释:逗号表达式,连续运算,一般最后一个数会作为表达式的结果
待续…
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- Redux系列02:一个炒鸡简单的react+redux例子
- JavaScript 各种遍历方式详解
- call/apply/bind 的理解与实例分享
- 如何创建对象以及jQuery中创建对象的方式
- 数组方法汇总