JavaScript数据类型及运算符

1 JavaScript 定义了几种数据类型? 哪些是原始类型?哪些是复杂类型?原始类型和复杂类型的区别是什么?

答:JavaScript定义了六种数据类型。分别是:

  • 数值(number):整数和小数。

  • 字符串(string):字符组成的文本

  • 布尔值(boolean):true和false两个值

  • undefined:表示未定义或不存在,即此处目前没有任何值

  • null:表示空缺,即此处应该有一个值,但目前为空

  • Object:对象,各种值组成的集合


  • 数值,字符串,布尔值为原始类型(primitive type)的值,即它们是最基本的数据类型,不能再细分了。将对象看作是复杂数据类型的值,因为一个对象往往是多个原始数据类型的的合成,可以看作是各种值的容器。原始类型和复杂类型在定义时的区别是原始类型直接赋值,对象定义时是引用。

    2 typeof和instanceof的作用和区别?

    答:type的作用是判断一个值的数据类型:

    typeof 1// "number"
    typeof "123" //"string"
    typeof true // "boolean"
    function f(){};
    typeof f;//"function"
    typeof undefined //"undefined"
    typeof window //"object"
    typeof {} //"object"
    typeof [] ////"object"
    typeof null //"object"

    instanceof 用于一个变量是否属于某个对象的实例,运算符返回一个布尔值,而且区分数组与对象。
    instanceof 只能用于判断对象和函数,不能用来判断字符串和数字等。

    3 如何判断一个变量是否是数字、字符串、布尔、函数

    答:typeof a === "number";typeof a === "string"; typeof a === "boolean";typeof a ==="function";

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

    答:表示not a number。NaN和任何值都不相等,包括它自己。在无法出现想要出现的数字结果时就以NaN代替。

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

    答:有三个函数可以将非数值转换成数值,1 Number(),2 parseInt(),3 parseFloat()。

    6 ==与===有什么区别

    答:==为近似相等,===为严格相等。使用==的时候,JavaScript会帮我们做类型上的转换,会造成一些预想不到的结果。

    7 break与continue有什么区别

    答:break上跳出循环体,执行下一条语句。continue为结束这次循环,进入下一次循环。

    8 void 0 和 undefined在使用场景上有什么区别?

    答:都可用于执行但返回值的情况下,但undefined不是关键字,因此有可能用户自定义了defined,会出现冲突,而void 0
    不会出现这样的问题。

    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; //输出结果2
    typeof a+2;//输出结果为number2

    11. 以下代码的输出结果是? 为什么

     var a = 1;
    var b = 3;
    console.log( a+++b );//输出结果为4,因为a+++b运行时,先计算a++,结果为1,1+3为4,结束后a为2.

    12. 遍历数组,把数组里的打印数组每一项的平方


    var arr = [3,4,5];
    //遍历数组,把数组里的打印数组每一项的平方
    for(var i=0;i< arr.length;i+=1){
    console.log(arr[i]*arr[i]);
    }

    13. 遍历 JSON, 打印里面的值


    var obj = {
    name: 'hunger',
    sex: 'male',
    age: 28
    }

    //遍历 JSON,打印里面的值
    for(key in obj){
    console.log(key+":"+obj[a]);
    }

    14. 以下代码输出结果是? 为什么 ?



    var a = 1, b = 2, c = 3;
    var val = typeof a + b || c >0
    console.log(val) //number2 undefined

    var d = 5;
    var data = d ==5 && console.log('bb')
    console.log(data) //bb undefined undefined

    var data2 = d = 0 || console.log('haha')
    console.log(data2) // haha undefined undefined

    var x = !!"Hello" + (!"world", !!"from here!!");
    console.log(x) //2 undefined

    你可能感兴趣的:(JavaScript数据类型及运算符)