JavaScript之隐式类型转换
2018-06-24 01:48:44来源:未知 阅读 ()
布尔操作符(!、&&、||)
当使用 条件判断语句(if...else) 以及 布尔操作符(!、&&、||) 时,会调用Boolean()进行隐式类型转换
- 转换为false的有:0, null, undefined, NaN, '', false
- 其余都为true([], {}为true)
![]; // !Boolean([]); ------------> false !2; // false !null; // !Boolean(null); ------------> true !undefined; // true !0; // true if([]) consolo.log('true'); // if(Boolean([])) ... -----------> true
乘/除法操作符(*、/)
- 若有一个操作数为NaN,则结果为NaN
- 若其中一个操作数不为数字,则调用Number()将其转换为数值
2 * '5'; // 10 2 * '5a'; // 2 * Number('5a') --------> 2 * NaN ------------> NaN
加法操作符(+)
- 若有一个操作数为NaN,结果为NaN
- 若有一个操作数为字符串,则将另一个数转换为字符串然后拼接
- 若有一个操作数为对象,则调用对象的toString方法再执行上一步
// num: 数值操作数 str: 字符串 obj: 对象 num + 非字符串操作数(NaN/undefined/null/false/true) = num + Number(非字符串操作数) num + str = 'numstr'; // 1 + 2 + '3' = '33' str + NaN = 'strNaN'; // '1' + NaN = '1NaN' str + null = 'strnull'; // '1' + null = '1null' str + true = 'strture'; obj + num = obj.toString() + num; // Math + 123 = '[object Math]123' obj + str = obj.toString() + str; // Math + '123' = '[object Math]123'
减法操作符(-)
- 若一个操作数为字符串、null、undefined、布尔值,就调用Number()将其转换为数值再运算
- 若一个操作数为对象则调用该对象valueOf(),没有valueOf()则调用toString()
1 - '2' = -1; 1 - '123a' = NaN; // 1 - Numer('123a') 1 - Math = NaN; // 1 - Math.valueOf() 1 - true = 0;
关系操作符(>、<、>=、<=)
- 与NaN比较都会返回false
- 若两个操作数都为字符串,则比较字符串的编码值
- 若有一个操作数为数值,则对另一个操作数用Number()转换
- 若有一个操作数为对象,则调用该对象valueOf(),没有valueOf()则调用toString()
4 > '2'; // true 4 > '2a'; // false 4 > Math; // false 4 > true; // true 'ab' > 'a' // true
相等操作符(==、!=)
- 字符串、布尔类型和数值比较,现将前者用Number()转换为数值
- 若一个操作数是对象另一个不是,则调用该对象valueOf(),没有valueOf()则调用toString()
- 若两个操作数都是对象,则比较它们是不是同一个对象(地址是否相同)
- null和undefined是相等的
- null和undefined不会转换成任何值
- 任何数都不等于NaN,包括NaN自己
// true 123 == '123'; 1 == true; '123' == new String(123); 123 == new String(123); null == undefined; // false null == 0; 2 == true; new String(123) == new String(123);
全等操作符(===、!==)
全等操作符不会转换操作数
123 === '123'; // false null === undefined; // false
总结
你能说说下面结果是什么以及原因吗?
[] == 0; // 1.?? {} == 0; // 2.?? 0 == {}; // 3.?? [] == {}; // 4.??
- true
- true
- error: Uncaught SyntaxError: Unexpected token ==
- false
根据相等操作符的规定,当一个操作数为对象另一个不是时,会调用对象的valueOf()
[] == 0; ---------> [].valueOf() -----> '' -----> Number('') ----> 0
当两个操作数都为对象则会比较它们是否指向同一块区域,而[]和{}是两个独立的对象,所以为false。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:vue小白快速入门
下一篇:vue内置指令详解——小白速会
- javascript面向对象入门基础详细介绍 2020-03-29
- JavaScript函数表达式详解及实例 2020-03-25
- 如何用javascript连接access数据库 2020-03-20
- js中去掉字串左右空格 2020-03-20
- Javascript中的经典技巧 2020-03-20
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash