数据类型运算符流程控制语句

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

数据类型运算符流程控制语句_第1张图片

instanceof作用是判断一个对象是不是由某个构造函数创建的实例。返回结果是true或false

数据类型运算符流程控制语句_第2张图片
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
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

你可能感兴趣的:(数据类型运算符流程控制语句)