JS 数据类型

JS 数据类型

JS 中内存的分类

  • 栈内存:用来提供一个供 JS 代码执行的环境->作用域(全局作用域/私有作用域),基本数据类型都存在栈内存里
  • 堆内存:用来存储引用数据类型的值->对象存储的是属性名和属性值,函数存储的是代码字符串…

JS 数据类型

  • 基本数据类型:String,Number,Boolean,Null,Undefined,Symbol。

    值类型(不互相干扰)

  • 引用数据类型:Object,Array,Function

    引用类型(地址,相互改变有影响)

检测数据类型

  • typeof:优点:能够快速区分基本数据类型 缺点:不能将 Object、Array 和 Null 区分,都返回 object

  • instanceof:优点:能够区分 Array、Object 和 Function,适合用于判断自定义的类实例对象 缺点:Number,Boolean,String 基本数据类型不能判断。原理:判断实例对象的属性和构造函数的属性是不是引用的同一个地址

    console.log(2 instanceof Number); // false
    console.log([] instanceof Array); // true
    
  • constructor 构造函数

  • Object.prototype.toString.call():优点:精准判断数据类型 缺点:写法繁琐不容易记,推荐进行封装后使用

    var toString = Object.prototype.toString;
    console.log(toString.call(2)); //[object Number]
    

类型转换(强制类型转化、隐式类型转化)

  • 强制类型转化:parseInt,parseFloat,toString,Boolean(),Number(),!!
  • 隐式类型转化:
    • 函数类:isNaN() 会对参数进行隐式的 Number()转换,如果转换不成功,则会返回 true
    • 条件类:if 隐式的调用 Boolean()函数
    • 逻辑运算:
      • 1: - \* / % 会隐式的调用 Number(),如果转换不成功,整个表达式返回 NaN
      • 2: + 数字会相加,字符串会隐式的调用 toSting()方法,然后拼接字符串
      • 3:如果都是 boolean 相加,进行 Number()转换,false 为 0 true 为 1,再相加console.log(false+true) // 1
      • 4:==
false=='' //true
null==undefined //true
obj.a==null 相当于 obj.a===null||obj.a===undefined
const a = 0
!a //true
!!a //false
!!0 === false //true
!!NaN === false //true
!!null ===false //true
!!undefined === false //true
10&&0 //0
abc||'' //abc

!和!!的区别:

  • !将变量转换成 boolean 类型,除了 null、undefined 和""空字符串取反都为 true,其余都为 false!null=true / !undefined=true / !''=true / ![]=false / !11=false

  • !!是将表达式强制转化为 bool 值的运算,运算结果为 true 或 false

    let a
    // a有内容才执行的代码
    if(a!=null&&typeof(a)!=undefined&&a!=''){}
    // 可以写成
    if(!!a){}
    // 因为
    !!(NaN || undefined || null || 0 || ' ')=false;
    

=区别:

  • ==, 两边值类型不同的时候,要先进行类型转换,再比较

  • ===,不做类型转换,类型不同的一定不等。

    ==类型转换过程:

    • 如果类型不同,进行类型转换
    • 判断比较的是否是 null 或者是 undefined, 如果是, 返回 true .
    • 判断两者类型是否为 string 和 number, 如果是, 将字符串转换成 number
    • 判断其中一方是否为 boolean, 如果是, 将 boolean 转为 number 再进行判断
    • 判断其中一方是否为 object 且另一方为 string、number 或者 symbol , 如果是, 将 object 转为原始类型再进行判断

    经典面试题:[] == ![] 为什么是 true 转化步骤:

    • !运算符优先级最高,![]会被转为为 false,因此表达式变成了:[] == false
    • 根据上面第(4)条规则,如果有一方是 boolean,就把 boolean 转为 number,因此表达式变成了:[] == 0
    • 根据上面第(5)条规则,把数组转为原始类型,调用数组的 toString()方法,[]转为空字符串,因此表达式变成了:’’ == 0
    • 根据上面第(3)条规则,两边数据类型为 string 和 number,把空字符串转为 0,
      因此表达式变成了:0 == 0 两边数据类型相同,0==0 为 true
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值