码迷,mamicode.com
首页 > Web开发 > 详细

js隐式转换个人总结

时间:2015-05-30 16:36:31      阅读:115      评论:0      收藏:0      [点我收藏+]

标签:

隐式转换在js中通常可以通过parseInt(),  Number(), String(), Boolean()等函数转换成对应的数据类型, 但通常为了简便, 我们会用特殊的写法进行转换, 比如:

var a = 5;
console.log( a + ‘‘ );    // 输出‘5‘, 将number类型转成string类型

  

//这里是将string转换成number类型

console.log( +‘56‘ );    //输出 56, 等价于Number(a)
console.log( -‘56 );     //输出-56

console.log( +‘‘ );      //0
console.log( +‘34A‘ ); // 输出NaN 
console.log( -‘34A‘ ); // 输出NaN
console.log( parseInt(‘34A‘, 10) ); //输出34; 
//parseInt第二个参数最好传入10, 如果不传, 在ES3中, 默认是转换成8进制

console.log( +[] );    //0 

  

  

//将string或number转成boolean值

console.log( !5 );      //false, 此过程会先将5转成true, 然后取非
console.log( !!5 );     //true, 等价于Boolean(5)
console.log( !!‘2‘ );   //true
console.log( !!‘‘ );    //false
console.log( !!0 );     //false
console.log( !![] );    //true
console.log( !!{} );    //true
console.log( !!null );      //false
console.log( !!undefined ); //false
console.log( !!/abc/g  );   //true

总结:

  1. 任何数据类型和字符串相加, 得到的都是字符串.
  2. 只有空数组(如果数组中有一个元素, 且这个元素也只能被转成0),  空字符串, 全是空格的字符串,  false 才会被转成0, 其他的看情况
  3. 只有null, undefined, 空字符串, 0, NaN才会被转成false, 其他全是true
  4. 如果你能确保字符串是由纯数字组成, 可以在前面用"+"将其转换成number类型, 省时省力.(jquery中不少这种写法)
  5. 判断语句中还是用 === 来进行严格判断, 避免不必要的麻烦

因此, [] == ![] 得到的是true,  因为右边的 ![] 会被先转换成 false, 然后因为是==且两边数据类型不一样, 所以两边会被转成number进行比较, 左边的[]转成number是0, 右边false也转成0, 所以相等返回true

 

需要注意一点:  null == undefined 比较中得到的是true

 

以上纯属个人总结,  如有错误, 欢迎指正.

 

js隐式转换个人总结

标签:

原文地址:http://www.cnblogs.com/flfwzgl/p/4540463.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!