进阶-任务2

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、如何判断一个变量是否是数字、字符串、布尔、函数

进阶-任务2_第1张图片

4、NaN是什么? 有什么特别之处?

NaN含义是Not a Number,表示非数字,NaN和任何值都不相等,包括自己。

5、如何把非数值转化为数值?

  1. Number( )
  1. parseInt( )
  2. 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

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

你可能感兴趣的:(进阶-任务2)