1、JavaScript 定义了几种数据类型? 哪些是原始类型?哪些是复杂类型?原始类型和复杂类型的区别是什么?
- JS语言的每一个值,都属于某一种数据类型,共有六种:
1、数值:整数和小数;
2、字符串:字符组成的文本(比如“hello world”);
3、布尔值:true(真)和false(假)两个特定值;
4、undefined:表示“未定义”或不存在,即此处目前没有任何值(未赋值);
5、null:表示空缺,即此处应该有一个值,但目前为空;
6、对象:各种值组成的集合。 - 原始类型:数值、字符串、布尔值,即它们是最基本的数据类型,不能再细分了。
- 复杂类型:对象,因为一个对象往往是多个原始类型的值的合成,可以看作是一个存放各种值的容器。
至于undefined和null,一般将它们看成两个特殊值。
2、typeof和instanceof的作用和区别?
- typeof运算符可以用来检查一个没有声明的变量,而不报错。实际编程中,这个特点通常用在判断语句。例如
if (typeof v === “undefined”){}
只能检测出部分简单的原始类型数据,例如数值返回number、字符串返回string、布尔值boolean;函数返回function;undefined 返回undefined。
而对于复杂类型数据,则无法区分,例如无法区分数组和对象、null,都返回object。 - instanceof运算符;判断一个东西是不是由某个构造函数所创建的实例,例判断是不是数组。
3、如何判断一个变量是否是数字、字符串、布尔、函数?
使用typeof运算符判断
Paste_Image.png
4、NaN是什么? 有什么特别之处?
- NaN是JavaScript的特殊值,表示“非数字”(Not a Number),主要出现在将字符串解析成数字出错的场合。NaN不是一种独立的数据类型,而是一种特殊数值,它的数据类型依然属于Number。
- 特点:NaN不等于任何值,包括它本身。NaN在布尔运算时被当作false。NaN与任何数(包括它自己)的运算,得到的都是NaN。
5、如何把非数值转化为数值?
可以用下面函数将非数值转化为数值
Number()
parseInt()
parseFloat()
6、==与===有什么区别?
- ==,相等运算符隐藏的类型转换,将不同类型的数据转化成数值后比较;===为严格相等运算符,是否为同一个值。
- 区别是相等运算符(==)比较两个值是否相等,严格相等运算符(===)比较它们是否为“同一个值”。如果两个值不是同一类型,严格相等运算符(===)直接返回false,而相等运算符(==)会将它们转化成同一个类型,再用严格相等运算符进行比较。
7、break与continue有什么区别?
break语句和continue语句都具有跳转作用,可以让代码不按既有的顺序执行。
break语句用于跳出代码块或循环。
continue语句用于立即终止本轮循环,返回循环结构的头部,开始下一轮循环。
8、void 0 和 undefined在使用场景上有什么区别?
void 运算符通常只用于获取 undefined 的原始值,一般使用 void(0)(等同于 void 0)。在上述情况中,也可以使用全局变量undefined 来代替(假定其仍是默认值)。
void 可以给任何给定的表达式求值,并返回 undefined,并且 void 不可被重写。
undefined:表示“未定义”或不存在,即此处目前没有任何值(未赋值)。
9、以下代码的输出结果是?为什么?
Paste_Image.png
console.log(1+1);
输出2console.log("2"+"4")
输出"24"console.log(2+"4")
输出"24"console.log(+"4")
输出4若两个运算子都是原始类型,只要有一个运算子是字符串,则两个运算子都转为字符串,执行字符串连接运算;否则,两个运算子都转为数值,执行加法运算。
加法运算符一定有左右两个运算子,如果只有右边一个运算子,就是另一个运算符,叫做“数值运算符”。
10、 以下代码的输出结果是?
var a=1;
a+++a; //输出3,先执行a++=1,此时a=2,则(a++)+a=1+2=3;
typeof a+2; //输出"number2",typeof优先,number+2=number2
11、以下代码的输出结果是? 为什么
Paste_Image.png
var a=1;
var b=3;
console.log(a+++b); //输出4,(a++)+b=1+3=4
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 (a in obj){
console.log(a+":"+obj[a])
}
14、以下代码输出结果是? 为什么 (选做题目)
var a=1,b=2,c=3;
var val=typeof a+b || c>0;
console.log(val)
输出number2;因为typeof优先级最高,||左边为number2,为true,所以返回第一个运算子的值
var d=5;
var data=d==5 && console.log('bb')
console.log(data)
输出为'bb',因为&&左边第一个运算子的布尔值为true,所以输出第二个运算子的值
var data2=d=0 || console.log('haha');
console.log(data2);
输出为'haha', 因为||左边运算子的布尔值为false,所以输出第二个运算子的值
var x=!!"Hello" + (!"world", !!"from here!!");
console.log(x)
输出为2,因为X=true+(false, true)=2