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

js常用算术运算符与一元运算符在做运算时不同类型的转换规则

时间:2019-10-21 13:15:25      阅读:107      评论:0      收藏:0      [点我收藏+]

标签:负数   规则   产生   结果   foo   type   算术运算   efi   pre   

/**
 * 算术运算符:+, -, *, /, %
 * 当对非number类型的值进行运算(-, *, /, %)时,会将这些值先转换成number再运算,加法‘+‘运算除外,
 * 当对非number类型(string, object)的值做加法(+)运算时会将这些值先转换成string再做拼接而不是相加
 * number类型的值与NaN做运算都是NaN
 */
// number
console.log(`1 + 1 = ${1 + 1}`); // 1 + 1 = 2
console.log(`1 + NaN = ${1 + NaN}`); // 1 + NaN = NaN
// string
console.log(`1 + ‘foo‘ = ${1 + ‘foo‘}`); // 1 + ‘foo‘ = 1foo
// boolean
console.log(`1 + true = ${1 + true}`); // 1 + true = 2
console.log(`1 + false = ${1 + false}`); // 1 + false = 1
// null
console.log(`1 + null = ${1 + null}`); // 1 + null = 1
// undefined
console.log(`1 + undefined = ${1 + undefined}`); // 1 + undefined = NaN
// object
console.log(`1 + (new Object()) = ${1 + (new Object())}, typeof (new Object()) = ${typeof (new Object())}`); // 1 + (new Object()) = 1[object Object], typeof (new Object()) = object

/**
 * 一元运算符:-, +
 * 对于number类型数字,+不会对数字产生影响,-将数字转换成负数
 * 对于非number类型的值,会先将值转换成number再做运算
 */
// number
console.log(`+1 = ${+1}`); // +1 = 1
console.log(`-1 = ${-1}`); // -1 = -1
console.log(`+NaN = ${+NaN}`); // +NaN = NaN
// string
console.log(`+‘a‘ = ${+‘a‘}`); // +‘a‘ = NaN
console.log(`+‘‘ = ${+‘‘}`); // +‘‘ = 0
console.log(`+‘1‘ = ${+‘1‘}`); // +‘1‘ = 1
// boolean
console.log(`-true = ${-true}`); // -true = -1
console.log(`-false = ${-false}`); // -false = 0
// null
console.log(`-null = ${-null}`); // -null = 0
// undefined
console.log(`-undefined = ${-undefined}`); // -undefined = NaN
// object
console.log(`+(new Object()) = ${+(new Object())}`); // +(new Object()) = NaN

// 注意:以上显示结果仅是在谷歌浏览器下(正式版本71.0.3578.98 (64位))

 

js常用算术运算符与一元运算符在做运算时不同类型的转换规则

标签:负数   规则   产生   结果   foo   type   算术运算   efi   pre   

原文地址:https://www.cnblogs.com/goujian/p/11712846.html

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