美文网首页
数字类型+运算符

数字类型+运算符

作者: 李永州的FE | 来源:发表于2017-06-03 17:26 被阅读0次

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

    原始:Number,String,boolean,null,undefined

    复杂:Array,Function,Obejct,

    复杂类型(对象)往往是多个原始类型的值的合成

    2 typeof和instanceof的作用和区别?

    就一句话,一个判断基本类型(除了null),一个判断数组和函数(这种复杂类型,简单类型判断不了,比如a是字符串就判断不了它是字符串的实例)

    typeof 123 // "number"
    typeof '123' // "string"
    typeof false // "boolean"
    typeof f// "function"
    typeof undefined// "undefined"
    typeof window // "object"
    typeof {} // "object"
    typeof [] // "object"
    typeof null // "object"
    
    所以常用typeof判断基本类型
    
    • instanceof用于判断一个变量是否某个对象的实例,运算符返回一个布尔值。
      instanceof只能用来判断对象和函数,不能用来判断字符串和数字等(这是重点)

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

    typeof 123 === 'number' 判断是否是数字
    typeof '123' === 'string' 判断是否为字符串
    typeof true ==='boolean' 判断是否为布尔
    typeof a ==='function' 判断是否为函数(根据上面也可以用instanceof)

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

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

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

    Number()
    parseInt()

    parseInt('11') // 11
    parseInt('11',2) //2+1=3
    第一个为string、第二个为解析的基数radix即以几进制解析,默认为10。(原则是字符串的每一位大小不能超过后面那个数)

    parseFloat()

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

    ===是严格意义的相等,只需注意NaN和NaN不等就行了。
    ==是值相等,javascript会帮我们做类型转换

    如果两个值类型相同,则执行严格相等的运算
    如果两个值的类型不同
    如果一个是null,一个是undefined,那么相等(这个背下来)
    如果一个是数字,一个是字符串,先将字符串转为数字,然后比较
    如果一个值是true/false则将其转为1/0比较
    如果一个值是对象,一个是数字或字符串,则尝试使用valueOf和toString转换后比较(怎么理解呢)

    8void 0 和 undefined在使用场景上有什么区别(不懂)

    the undefined property of the global object (window.undefined on browser environments) is writable, whereas the void operator will return the undefined value always.

    10. 以下代码的输出结果是?

    var a = 1;  
    a+++a; //(a++)+a前面括号值为1,但是a已经变为2,所以是1+2=3
    typeof a+2;//输出"number2",typeof的优先级高于+运算,所以输出字符串number,字符串与数字相加时,数字转换为字符串,然后字符串拼接就变成"number2"
    

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

     var a = 1;
     var b = 3;
     console.log( a+++b );//1+3=4,++优先级高于+
    

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

    var obj = {
     name: 'hunger', 
     sex: 'male', 
     age: 28 
    }
    for(key in obj){
    console.log(key+":"obj[key]);
    }
    

    14. 以下代码输出结果是? 为什么 (当时好像做错了呢,下面是错误答案)

    var a = 1, b = 2, c = 3;
    var val = typeof a + b || c >0
    console.log(val) //number2;结果为number2,只要“||”前面为true,无论“||”后面是true还是false,结果都返回“||”前面的值。
    
    var d = 5;
    var data = d ==5 && console.log('bb')
    console.log(data)//结果为bb,只要“&&”前面是false,无论“&&”后面是true还是false,结果都将返“&&”前面的值,前面若是true,则无论你后面是什么都只返回后面的值
    
    var data2 = d = 0 || console.log('haha')
    console.log(data2)//haha,结果为haha,只要“||”前面为false,无论“||”后面是true还是false,结果都返回“||”后面的值
    
     var x = !!"Hello" + (!"world", !!"from here!!");
    console.log(x)//结果为2,空字符串为false,非空则为true,var x = true+(false+true),true为1,1+1=2。
    
    
    

    总结:

    • 对于||来说,前面为真返回前面,前面为假返回后面
    • 对于&&来说,前面为假返回前面,前面为真返回后面

    相关文章

      网友评论

          本文标题:数字类型+运算符

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