1 javaScript 定义了几种数据类型? 哪些是原始类型?哪些是复杂类型?原始类型和复杂类型的区别是什么?
原始:Number,String,boolean,null,undefined
复杂:Array,Function,Obejct,
复杂类型(对象)往往是多个原始类型的值的合成
2 typeof和instanceof的作用和区别?
就一句话,一个判断基本类型(除了null),一个判断数组和函数(这种复杂类型,简单类型判断不了,比如a是字符串就判断不了它是字符串的实例)
typeof 123 // "number"
typeof '123' // "string"
typeof false // "boolean"
typeof f// "function"
typeof undefined// "undefined"
typeof window // "object"
typeof {} // "object"
typeof [] // "object"
typeof null // "object"
所以常用typeof判断基本类型
- instanceof用于判断一个变量是否某个对象的实例,运算符返回一个布尔值。
instanceof只能用来判断对象和函数,不能用来判断字符串和数字等(这是重点)
3如何判断一个变量是否是数字、字符串、布尔、函数
typeof 123 === 'number' 判断是否是数字
typeof '123' === 'string' 判断是否为字符串
typeof true ==='boolean' 判断是否为布尔
typeof a ==='function' 判断是否为函数(根据上面也可以用instanceof)
4NaN是什么? 有什么特别之处?
NaN含义是Not a Number,表示非数字,NaN和任何值都不相等,包括自己
5如何把非数值转化为数值?
Number()
parseInt()
parseInt('11') // 11
parseInt('11',2) //2+1=3
第一个为string、第二个为解析的基数radix即以几进制解析,默认为10。(原则是字符串的每一位大小不能超过后面那个数)
parseFloat()
6==与===有什么区别
===是严格意义的相等,只需注意NaN和NaN不等就行了。
==是值相等,javascript会帮我们做类型转换
如果两个值类型相同,则执行严格相等的运算
如果两个值的类型不同
如果一个是null,一个是undefined,那么相等(这个背下来)
如果一个是数字,一个是字符串,先将字符串转为数字,然后比较
如果一个值是true/false则将其转为1/0比较
如果一个值是对象,一个是数字或字符串,则尝试使用valueOf和toString转换后比较(怎么理解呢)
8void 0 和 undefined在使用场景上有什么区别(不懂)
the undefined property of the global object (window.undefined on browser environments) is writable, whereas the void operator will return the undefined value always.
10. 以下代码的输出结果是?
var a = 1;
a+++a; //(a++)+a前面括号值为1,但是a已经变为2,所以是1+2=3
typeof a+2;//输出"number2",typeof的优先级高于+运算,所以输出字符串number,字符串与数字相加时,数字转换为字符串,然后字符串拼接就变成"number2"
11. 以下代码的输出结果是? 为什么
var a = 1;
var b = 3;
console.log( a+++b );//1+3=4,++优先级高于+
13. 遍历 JSON, 打印里面的值`
var obj = {
name: 'hunger',
sex: 'male',
age: 28
}
for(key in obj){
console.log(key+":"obj[key]);
}
14. 以下代码输出结果是? 为什么 (当时好像做错了呢,下面是错误答案)
var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0
console.log(val) //number2;结果为number2,只要“||”前面为true,无论“||”后面是true还是false,结果都返回“||”前面的值。
var d = 5;
var data = d ==5 && console.log('bb')
console.log(data)//结果为bb,只要“&&”前面是false,无论“&&”后面是true还是false,结果都将返“&&”前面的值,前面若是true,则无论你后面是什么都只返回后面的值
var data2 = d = 0 || console.log('haha')
console.log(data2)//haha,结果为haha,只要“||”前面为false,无论“||”后面是true还是false,结果都返回“||”后面的值
var x = !!"Hello" + (!"world", !!"from here!!");
console.log(x)//结果为2,空字符串为false,非空则为true,var x = true+(false+true),true为1,1+1=2。
总结:
- 对于||来说,前面为真返回前面,前面为假返回后面
- 对于&&来说,前面为假返回前面,前面为真返回后面