1、JavaScript 定义了几种数据类型? 哪些是原始类型?哪些是复杂类型?原始类型和复杂类型的区别是什么?
类型 | 定义 | 区别 |
---|---|---|
数值(number) | 整数和小数(比如1和3.14) | 原始类型 |
字符串(string) | 字符组成的文本(比如"Hello World") | 原始类型 |
布尔值(boolean) | true(真)和false(假)两个特定值 | 原始类型 |
对象(object) | 各种值组成的集合 | 复杂类型 |
undefined | 表示“未定义”或不存在,即此处目前没有任何值 | 特殊值 |
null | 表示空缺,即此处应该有一个值,但目前为空 | 特殊值 |
symbol | ES6 Symbols也是一个集,但它的元素既不是字符串也不是对象。它是ES6的新成员:第七种基本类型。 | ES6 |
- 原始类型:最基本的数据类型,不能再细分了。
- 复杂类型:因为一个对象往往是多个原始类型的值的合成,可以看作是一个存放各种值的容器。
2、typeof 和instanceof 的作用和区别?
typeof:一元运算符,用来说明运算的数据类型,返回值是字符串。
(typeof 有一个实际应用场景,就是用来检测一个对象是否已经定义或者是否已经赋值。而这个应用却不是来检查对象的类型。)
- 原始类型中的数值、字符串、布尔值分别返回number、string、boolean。
- 函数返回function。
- undefined返回undefined。(type of undefined 可以用来检查一个没有声明的变量,而不报错。)
- 除此以外,其他情况都返回object。
instanceof:可以判断一个变量是否是某个对象(类)的实例,返回值是布尔类型。
3、如何判断一个变量是否是数字、字符串、布尔、函数
4、NaN是什么? 有什么特别之处?
NaN含义是Not a Number,表示非数字,NaN和任何值都不相等,包括自己。
5、如何把非数值转化为数值?
- Number( )
- parseInt( )
- parseFloat( )
其中 parseInt parseFloat
- 忽略字符串前面的空白字符,找到第一个非空白字符
- 如果第一个字符不是-或者数字返回NaN
- 如果是继续解析,直到非数值模式为止
- 0开头会当做八进制,0x开头会当做十六进制,但是可以指定第二个参数指定基数
6、==与===有什么区别
=== 严格相等。只需注意NaN和NaN不等
== 相等。使用时:
- 如果两个值类型相同,则执行严格相等的运算
- 如果两个值的类型不同
(1) 如果一个是null,一个是undefined,那么相等
(2) 如果一个是数字,一个是字符串,先将字符串转为数字,然后比较
(3) 如果一个值是true/false则将其转为1/0比较
(4) 如果一个值是对象,一个是数字或字符串,则尝试使用valueOf和toString转换后比较
(5) 其它就不相等了
7、break与continue有什么区别
- break 用于强制退出循环体,执行循环后面的语句
- continue 用于退出本次循环,执行下次循环
8、void 0 和 undefined在使用场景上有什么区别
一般多数情况下,void 0===undefined。但区别还是有的:
- undefined它不是保留词,是一个属性,在一些低版本的浏览器中的某些局域变量里是可以被重写的。
- void这个运算符对给定的表达式求值,然后返回undefined。意思是只要void后面跟任何东西,返回的都是undefined。用这个就不用担心被重定义undefined了。那void后面最短的,就是0了,void也不能被重写。而且void 0长度比undefined短,压缩有时也用它来代替undefined。
9、以下代码的输出结果是?为什么?
console.log(1+1); //结果为2 数字与数字相加。
console.log("2"+"4") //结果为"24" 两个字符串与字符串拼接。
console.log(2+"4") //结果为"24" 两个中有一个是字符串,会把另一个数字转化为字符串。
console.log(+"4") //结果为4 在只有一个字符串时,会尝试转化为数字。
10、以下代码的输出结果是?
var a=1;
a+++a; //结果为3
typeof a+2; //结果为number2
11、 以下代码的输出结果是? 为什么
var a = 1;
var b = 3;
console.log( a+++b ); //结果为4
a+++b相当于(a++)+b,a++是先赋值再加
12、遍历数组,把数组里的打印数组每一项的平方
var arr = [3,4,5]
for (var i=0; i<arr.length;i++) {
console.log(arr[i]*arr[i]);
}
13、遍历 JSON, 打印里面的值
var obj = {
name: 'hunger',
sex: 'male',
age: 28
}
for (i in obj) {
console.log(i+":"+obj[i]);
}
14、以下代码输出结果是什么
var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0
console.log(val) //number2 ||左侧为number2为true,忽略右侧。
var d = 5;
var data = d ==5 && console.log('bb')
console.log(data) //bb undefined
var data2 = d = 0 || console.log('haha')
console.log(data2) //haha undefined
var x = !!"Hello" + (!"world", !!"from here!!");
console.log(x) //2
网友评论