0%

运算符与类型转换

显示类型转换

1

显示转换,即我们很清楚可以看到这里发生了类型的转变,常见的方法有:

  • Number()
  • parseInt()
  • String()
  • Boolean()

Number()

将任意类型的值转化为数值

先给出类型转换规则:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
Number(324) // 324

// 字符串:如果可以被解析为数值,则转换为相应的数值
Number('324') // 324

// 字符串:如果不可以被解析为数值,返回 NaN
Number('324abc') // NaN

// 空字符串转为0
Number('') // 0

// 布尔值:true 转成 1,false 转成 0
Number(true) // 1
Number(false) // 0

// undefined:转成 NaN
Number(undefined) // NaN

// null:转成0
Number(null) // 0

// 对象:通常转换成NaN(除了只包含单个数值的数组)
Number({a: 1}) // NaN
Number([1, 2, 3]) // NaN
Number([5]) // 5

从上面可以看到,Number转换的时候是很严格的,只要有一个字符无法转成数值,整个字符串就会被转为NaN

parseInt()

parseInt相比Number,就没那么严格了,parseInt函数逐个解析字符,遇到不能转换的字符就停下来

1
1parseInt('32a3') //32

String()

可以将任意类型的值转化成字符串

给出转换规则图:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// 数值:转为相应的字符串
String(1) // "1"

//字符串:转换后还是原来的值
String("a") // "a"

//布尔值:true转为字符串"true",false转为字符串"false"
String(true) // "true"

//undefined:转为字符串"undefined"
String(undefined) // "undefined"

//null:转为字符串"null"
String(null) // "null"

//对象
String({a: 1}) // "[object Object]"
String([1, 2, 3]) // "1,2,3"

Boolean()

可以将任意类型的值转为布尔值,转换规则如下:

1
2
3
4
5
6
7
8
Boolean(undefined) // false
Boolean(null) // false
Boolean(0) // false
Boolean(NaN) // false
Boolean('') // false
Boolean({}) // true
Boolean([]) // true
Boolean(new Boolean(false)) // true

“|”运算符

它仅执行ToInt32转换

1
2
3
4
0|=0//0
0|NAN;//0
0|Infinity;//0
0|-Infinity;//0

以上字符无法以32位格式呈现,他们都来自64位IEE754标准,因此ToInt返回0

“~”运算符

它首先将值转为32位数字,然后执行字位操作“非”,对每一位进行反转,也就是返回2的补码,x相当于-(x+1),-(x+1)唯一能够得到0的x值时-1,也就是说如果x为-1,和一些数字值连在一起就会返回假值,其他情况返回真值

而-1是一个“哨位值”,即在各个类型中被赋予了特殊含义的值,如indexOf(),在字符串中找到指定字符返回子字符串所在位置,否则返回-1

1
2
3
4
5
6
7
8
9
10
11
var a="Hello world";
~a.indexOf("lo");//-4
if(~a.indexOf("lo")){//true
//找到匹配

}
~a.indexOf("ol");//0,假值
!~a.indexOf("ol");//true
if(!~a.indexOf("ol")){//true
//没有找到匹配
}

隐式类型转换

在隐式转换中,我们可能最大的疑惑是 :何时发生隐式转换?

我们这里可以归纳为两种情况发生隐式转换的场景:

  • 比较运算(==!=><)、ifwhile需要布尔值地方
  • 算术运算(+-*/%

除了上面的场景,还要求运算符两边的操作数不是同一类型

自动转换为布尔值

在需要布尔值的地方,就会将非布尔值的参数自动转为布尔值,系统内部会调用Boolean函数

可以得出个小结:

  • undefined
  • null
  • false
  • +0
  • -0
  • NaN
  • “”

除了上面几种会被转化成false,其他都换被转化成true

自动转换成字符串

遇到预期为字符串的地方,就会将非字符串的值自动转为字符串

具体规则是:先将复合类型的值转为原始类型的值,再将原始类型的值转为字符串

常发生在+运算中,一旦存在字符串,则会进行字符串拼接操作

1
2
3
4
5
6
7
8
1'5' + 1 // '51'
2'5' + true // "5true"
3'5' + false // "5false"
4'5' + {} // "5[object Object]"
5'5' + [] // "5"
6'5' + function (){} // "5function (){}"
7'5' + undefined // "5undefined"
8'5' + null // "5null"

自动转换成数值

除了+有可能把运算子转为字符串,其他运算符都会把运算子自动转成数值

1
2
3
4
5
6
7
8
9
10
11
1'5' - '2' // 3
2'5' * '2' // 10
3true - 1 // 0
4false - 1 // -1
5'1' - 1 // 0
6'5' * [] // 0
7false / '5' // 0
8'abc' - 1 // NaN
9null + 1 // 1
10undefined + 1 // NaN
null`转为数值时,值为`0` 。`undefined`转为数值时,值为`NaN

||和&&

在JS中||和&&返回的是两个操作数中的一个

||和&&首先会对第一个操作数(a和c)执行条件判断,如果其不是布尔值,就进行TooBoolean强制类型转换,然后再进行条件判断

对于||:

如果条件判断结果为true返回第一个操作数,为false则返回第二个操作数的值。

&&则相反,如果条件判断结果为true返回第二个操作数,如果为fakse返回第一个操作数

a||b相当于a?a:b;

a&&b相当于a?b:a

常见的用||

1
2
3
4
5
6
function foo(a,b){
a=a||"hello";//检查变量a如果未赋值则赋值一个默认值hello
b=b||"world";
console.log(a+" "+b);

}

&&:

1
2
3
4
5
function foo(){

}
var a=42;
a&&foo();//foo()只有在条件判断a通过时才会调用foo();如果条件判断未通过,则a&&foo()就会终止