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

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

作者: cross_王 | 来源:发表于2017-07-18 15:12 被阅读0次

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

    • JavaScript定义了7种数据类型,有六种原始数据类型:Undefined,Null,Boolean,Number,String,Symbol和一种复杂数据类型Object.
    • 原始类型和复杂类型的区别:
      1. 存储方式:原始类型存放在栈中,也就是存放在变量访问的位置;复杂类型存储在堆(heap)中,存储在变量处的值是一个指针,指向存储对象的内存处.
      2. 引用方式:原始类型是作为不可细化的值进行存储和操作的,引用它们会转移其值;复杂值是通过引用进行存储和操作的,而不是实际的值。创建一个包含复杂对象的变量时,其值是内存中的一个引用地址。引用一个复杂对象时,使用它的名称(即变量或对象属性)通过内存中的引用地址获取该对象值.
      3. 比较方式:原始类型采用值比较,而复杂类型采用引用比较。复杂类型只有在引用相同的对象(即有相同的地址)时才相等。即使是包含相同对象的两个变量也彼此不相等,因为它们并不指向同一个对象.
      4. 动态属性:对于复杂类型,可以为其添加属性和方法,也可以改变和删除其属性和方法;但原始类型不可以添加属性和方法.
      5. 包装类型: 原始类型被当作构造函数创建的一个对象来使用时,Javascript会将其转换成一个对象,以便可以使用对象的特性和方法,而后抛弃对象性质,并将它变回到原始类型.
    • 参考资料

    typeof和instanceof的作用和区别?

    • typeof 是一个一元运算,放在一个运算数之前,运算数可以是任意类型。它返回值是一个字符串,该字符串说明运算数的类型。typeof 一般只能返回如下几个结果number,boolean,string,function,object,undefined。我们可以使用 typeof 来获取一个变量是否存在,如 if(typeof a!="undefined"){alert("ok")},而不要去使用 if(a) 因为如果 a 不存在(未声明)则会出错,对于 Array,Null 等特殊对象使用 typeof 一律返回 object,这正是 typeof 的局限性。
    • instanceof 用于判断一个变量是否某个对象的实例,如 var a=new Array();alert(a instanceof Array); 会返回 true,同时 alert(a instanceof Object) 也会返回 true;这是因为 Array 是 object 的子类。
    • 跨框架检测数组

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

    var a;
    typeof a === "number";//判断是否是数字
    typeof a === "string";//判断是否是字符串
    typeof a === "boolean";//判断是否是布尔
    typeof a === "function";//判断是否是函数

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

    • NaN是一个特殊的数值,用于表示一个本来要返回数值的操作数未返回数值的情况.任何数字除以非数值就会返回NaN,因此不会影响其他代码的执行
    • NaN的特点:任何涉及NaN的操作都会返回NaN,NaN与任何值都不相等,包括它自己
    • 有isNaN()函数来判断一个值是否是NaN

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

    • 有三个函数可以把非数值转化为数值:Number(),parseInt(),parseFloat().

    ==与===有什么区别

    • ==是值相等,js会在一些情况下进行隐式的类型转换后再进行比较;
    • ===是严格相等,不会转换数据类型;

    break与continue有什么区别

    • break是结束一个循环,跳出循环体往下执行循环后面的语句
    • continue是结束本次循环,继续执行下一次循环

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

    • undefined 并不是保留词(reserved word),在局部作用域中,可以被重写。
    • void 是不能被重写的。 void 运算符能对给定的表达式进行求值,然后返回 undefined,最短的是void 0,所以用void 0 来表示undefined, 来避免undefined被改写。

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

    console.log(1+1);    
    console.log("2"+"4");  
    console.log(2+"4"); 
    console.log(+"4");
    

    2 //数字相加
    24 //字符串连接
    24 //数字与字符串相加:数字转换成字符串,然后与字符串连接
    4 //字符串连接符

    
    # 以下代码的输出结果是?
    

    var a = 1;
    a+++a;
    typeof a+2;

    -  
    

    "number2" //typeof的优先级大于+

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

    var a = 1;
    var b = 3;
    console.log( a+++b );

    -  
    

    4 //计算前a++ = 1, a+++b = 1+3 = 4

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

    var arr = [3,4,5]

    -  
    

    for(i = 0;i < arr.length;i++){
    console.log(Math.pow(arr[i],2));
    }

    
    #  遍历 JSON, 打印里面的值
    

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

    -  
    

    for(var pro in obj){
    console.log(obj[pro]);
    }

    
    # 以下代码输出结果是? 为什么 (选做题目)
    

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

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

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

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

    -  
    

    'number2' //先执行typeof a 得到'number','number'+2'='number2',转化为boolean为true,不再执行||右边,结果就是'number2'
    undefined //d==5结果是ture,&&运算左边为true要看右边,console.log()的返回值是undefined,所以data的值为undefined
    undefined //data2 = d = 0 || undefined结果是undefined
    2 // true+(false,true) true+true=2

    相关文章

      网友评论

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

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