JavaScript 定义了几种数据类型? 哪些是原始类型?哪些是复杂类型?原始类型和复杂类型的区别是什么?
数据类型分类
JavaScript语言的每一个值,都属于某一种数据类型。JavaScript的数据类型,共有六种。数值(number):整数和小数(比如1和3.14)
字符串(string):字符组成的文本(比如"Hello World")
布尔值(boolean):true(真)和false(假)两个特定值
undefined:表示“未定义”或不存在,即此处目前没有任何值
null:表示空缺,即此处应该有一个值,但目前为空
对象(object):各种值组成的集合
原始类型和复杂类型
数值、字符串、布尔值称为原始类型(primitive type)的值,即它们是最基本的数据类型,不能再细分了。
将对象称为复杂类型(complex type)的值,因为一个对象往往是多个原始类型的值的合成,可以看作是一个存放各种值的容器。
至于undefined和null,一般将它们看成两个特殊值。
typeof和instanceof的作用和区别?
-
typeof运算符可以返回一个值的数据类型,可能有以下结果。
- 原始类型
数值、字符串、布尔值分别返回number、string、boolean。
typeof 123 // "number"
typeof '123' // "string"
typeof false // "boolean"
- 原始类型
函数
函数返回function。
function f() {}
typeof f
// "function"undefined
undefined返回undefined。
typeof undefined
// "undefined"
如何判断一个变量是否是数字、字符串、布尔、函数
- typeof 123 === 'number' 判断是否是数字
- typeof '123' === 'string' 判断是否为字符串
- typeof true ==='boolean' 判断是否为布尔
- typeof a ==='function' 判断是否为函数
NaN是什么? 有什么特别之处?
- NaN含义是Not a Number,表示非数字,NaN和任何值都不相等,包括自己
如何把非数值转化为数值?
- 有三个函数可以把非数值转换为数值
- Number()
- parseInt()
- parseFloat()
==与===有什么区别?
===是严格意义的相等,只需注意NaN和NaN不等就行了。而使用==的时候,javascript会帮我们做类型转换,造成一些匪夷所思的结果,那么使用==的时候会在哪些情况下做类型转换,又会换成什么样子?
- 如果两个值类型相同,则执行严格相等的运算
- 如果两个值的类型不同
-如果一个是null,一个是undefined,那么相等 - 如果一个是数字,一个是字符串,先将字符串转为数字,然后比较
- 如果一个值是true/false则将其转为1/0比较
- 如果一个值是对象,一个是数字或字符串,则尝试使用valueOf和toString转换后比较
- 其它就不相等了
break与continue有什么区别?
break关键字在switch语句中已经见过,这两个关键字多用在循环语句中
break 用于强制退出循环体,执行循环后面的语句
continue 用于退出本次循环,执行下次循环
看个例子对比一下
for(var i = 1; i< 10; i++){
if(i % 4 === 0){
break;
}
console.log(i);
}
for(var i = 1; i< 10; i++){
if(i % 4 === 0){
continue;
}
console.log(i);
}
这是break和continue最常规的用法,其实这两个关键字后面可以跟上我们之前提到的label,退出指定位置的代码,对于多层循环是个有用的技巧,但是难以理解,一般不推荐使用(如同C语言中被误解的goto)
void 0 和 undefined在使用场景上有什么区别?
-void运算符的作用是执行一个表达式,然后返回undefined。
void 0的特点:
不管void后的运算数是什么,只管返回纯正的undefined;
void会对其后的运算数作取值操作,因此若属性有个getter函数,那么就会调用getter函数(因此会产生副作用)
用 void 0 代替 undefined 能节省不少字节的大小,事实上,不少 JavaScript 压缩工具在压缩过程中,正是将 undefined 用 void 0 代替掉了。
undefined表示不存在值,就是此处目前不存在任何值。典型用法是:
变量被声明了,但没有赋值时,就等于undefined。
调用函数时,应该提供的参数没有提供,该参数等于undefined。
对象没有赋值的属性,该属性的值为undefined。
函数没有返回值时,默认返回undefined。
以下代码的输出结果是?为什么?
console.log(1+1);
console.log("2"+"4");
console.log(2+"4");
console.log(+"4");
- console.log(1+1):数值,两个数字加法运算
- console.log("2"+"4"):字符串,两个字符串类型的做字符串拼接
- console.log(2+"4"):一个是数字一个是字符串,数字转化为字符串后拼接
- console.log(+"4"):只有一个字符串会转换成数字输出
以下代码的输出结果是?
var a = 1; // 1赋值给a
a+++a; // ++优先级比+高,相当于(a++)+a,3
typeof a+2; // 输出number2 ,typeof的优先级比+高
以下代码的输出结果是? 为什么
var a = 1;
var b = 3;
console.log( a+++b );//输出4,++运算优先于+运算,理解为(a++)+b,a++结果为1,运算为1+3=4。
以下代码的输出结果是? 为什么
var a = 1;
var b = 3;
console.log( a+++b );//输出4,(a++)+b,a++为1,1+3=4.
遍历数组,把数组里的打印数组每一项的平方
var arr = [3,4,5];
for(i=0;i<arr.length;i++) {
console.log(arr[i]*arr[i]);
}
遍历 JSON, 打印里面的值
var obj = {
name: 'hunger',
sex: 'male',
age: 28
}
for(var key in obj){
console.log(obj[key])
}
以下代码输出结果是? 为什么 (选做题目)
var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0
console.log(val) //number2
var d = 5;
var data = d ==5 && console.log('bb')
console.log(data)//bb
var data2 = d = 0 || console.log('haha')
console.log(data2)//haha
var x = !!"Hello" + (!"world", !!"from here!!");
console.log(x)//