美文网首页
数据类型运算符流程控制语句

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

作者: BAWScipes | 来源:发表于2017-09-21 17:48 被阅读0次
    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
    

    相关文章

      网友评论

          本文标题:数据类型运算符流程控制语句

          本文链接:https://www.haomeiwen.com/subject/ldjosxtx.html