1.JavaScriot定义了几种数据类型?哪些是原始类型?哪些是复杂类型?原始类型和复杂类型的区别是什么?
JavaScript的数据类型有七种:数值(number)、字符串(string)、布尔值(bool)、undefined、null、对象(object)、Symbol(ECMAScript 6 新定义,表示唯一值)
原始类型:数值(number)、字符串(string)、布尔值(bool)
复杂类型:对象(object)
对象:狭义的对象、数组(array)、函数(function)、正则表达式(regexp)
特殊值: undefined 未定义或不存在的值,没有任何值;null 空值,表示有值,值是空的。
区别:原始类型是最基本的数据类型,不能再细分;复杂类型是多个原始类型的值的合成,可以看成一个存放各种值的容器。
2.typeof与instanceof的作用和区别?
typeof的作用是返回一个值的数据类型,返回的结果是:number、string、boolean、undefined、object、function
instanceof作用是判断一个对象是不是由某个构造函数创建的实例。返回结果是true或false
3.如何判断一个变量是否是数字、字符串、布尔、函数
var a=123;
var b="hello";
var c=false;
function f() {}
typeof a ---number
typeof b ---string
typeof c ---boolean
typeof f ----function
4.NaN是什么?有什么特别之处?
NaN 含义是Not a Number,但它本身是一个数值类型,表示非数字值的特殊值。NaN与其他数值进行比较的结果总是不相等的,包括它本身在内。
typeof NaN ---number
typeof NaN === NaN ---false
typeof NaN !== NaN ---true
parseInt('abc') ---NaN
5.如何把非数值转换成数值?
有三个函数可以把非数值转换成数值
Number()函数、parseInt() 函数、parseFloat()函数
注意:
(1)忽略字符串前面的空白字符,找到第一个非空白字符。
(2)如果第一个字符不是-
或者数字返回NaN
。
(3)继续解析,直到是非数值模式为止
(4)0
开头会当成八进制,0x
开头会当成十六进制,但是可以指定第二个参数指定基数。
Number('13') //13
Number('13a') //NaN
parseInt('blue'); //NaN
parseInt('12a') //12
parseInt('-23a'); // -23
parseInt('0xf1'); // 241
parseInt('101', 2); // 5
parseFloat('12.3') //12.3
parseFloat('1.2a') //1.2
6.==与===有什么区别
==近似相等,比较值是否相等
===绝对相等,比较类型和值都要相等
undefined == null //true
undefined === null //false
NaN == NaN //false
NaN === NaN //false
"1" == true //true
"1" === true //false
7.break和 continue有什么区别
break用于强制退出循环体,执行循环后面的语句
continue用于退出本次循环,执行下次循环
8.void 0 和 undefined在使用场景上有什么区别
void执行一个表达式返回undefined,在某些情况下,undefined是可以被赋值的,比如在函数中,就不能用undefined来进行判断了,所以就可以用void 0 返回undefined来进行判断
9.以下代码的输出结果是什么?为什么?
console.log(1+1); //2
console.log("2"+"4"); //24
console.log(2+"4"); //24
console.log(+"4"); //4
输出结果 | 原因 |
---|---|
2 | 两个操作数都是数字,做加法运算 |
24 | 两个操作数都是字符串,字符串拼接 |
24 | 把数字2转换成字符串"2",然后字符串拼接 |
4 | 只有一个字符串参数的时候会尝试将其转化为数字 |
10.以下代码的输出结果是什么?
var a = 1; //undefined
a+++a; // 3 相当于(a++)+a,++的优先级高于+
typeof a+2; //"number2"
输出结果:"number2" ,typeof的运算优先级高于+,先计算typeof a,typeof a 的返回结果是"number" ,然后将数字2转换成字符串"2",最后字符串拼接
11.以下代码的输出结果是什么?为什么
var a = 1; //undefined
var b = 3; //undefined
console.log(a+++b);
输出结果:4,++的运算优先级高于+,相当于(a++)+b,自增a++是先赋值再加1,所以先执行a+b=4,然后执行a++=2
12.遍历数组,把数组里的打印数组每一项的平方
var arr = [3,4,5]
遍历数组用for循环
for(var i=0;i<arr.length;i++){
console.log(arr[i]*arr[i]);
}
输出结果: 9 16 25
13.遍历JSON,打印里面的值
var obj = {
name: 'hunger',
sex: 'male',
age: 28
}
遍历对象用for-in循环
for (var key in obj){
console.log(obj[key]);
}
输出结果: hunger male 28
14.以下代码输出结果是什么?为什么
var a = 1, b = 2, c = 3; //undefined
var val = typeof a + b || c >0 //undefined
console.log(val) //number2
(1)根据运算符优先级先算 typeof a,a=1是数字,结果为"number"
(2)然后计算+b,b=2,所以结果为"number2"
(3)c>0 为true,计算 "number2" || true
(4)输出结果number2
var d = 5; //undefined
var data = d ==5 && console.log('bb') //bb
console.log(data) //undefined
(1) 根据优先级 var data=(d==5)&&console.log('bb'),先计算d==5,结果为true
(2) console.log('bb'),输出bb,结果是undefined
(3) true && undefined,结果是undefined
(4)输出结果undefined
var data2 = d = 0 || console.log('haha') //haha
console.log(data2) //undefined
(1) 根据优先级 console.log('haha'),输出haha,结果是undefined
(2) || 的优先级高于=,计算 0 || undefined,结果是undefined
(3)输出结果undefined
var x = !!"Hello" + (!"world", !!"from here!!"); //undefined
console.log(x) //2
(1)根据优先级先计算小括号里的(!"world", !!"from here!!"),计算!"world",结果为false;计算 !!"from here!!",结果为true
(2)计算(false,true),结果为true
(3)true+true,结果为2,当+两边都是boolean,会把boolean转换成number,true==1,false==0,true+true结果为2
(4)输出结果2