js数据类型

js数据类型有哪些

   备注: 基本数据类型,又称值类型。

1. 常见的值类型:

在这里插入图片描述

 2.常见的引用类型:

  说明:因typeof 检测null返回object,故有些地方也成null为特殊引用类型。但我们最好还是归为基本类型。

在这里插入图片描述

3.typeof运算符:

 3.1  基本类型(值类型):

在这里插入图片描述

3.2 引用类型:

typeof function(){} //'function'
typeof null // 'object'
typeof {} // 'object'
typeof [1,2] // 'object'
.....

3.3 总结:

  • typeof 能有效检测基本类型,检测引用类型都返回object,其中null属于特殊的引用类型返回object,function属于特殊引用类型类型不用于存储数据,typeof检测返回function.

4.变量计算-类型转换

在这里插入图片描述

4.1. 字符串拼接

const a=100+200; // 200
const b=100+'200' // '100200'
const c='true'+'100' // 'true100'
  • 结论:+运算中有字符串,结果就是字符串拼接。

4.2. ==与===

在这里插入图片描述

在这里插入图片描述

 结论:

  • ===三等表示全等,判断左右两边对象或值是否类型相同且值相等。
  • ==二等表示值相等。判断操作符两边对象或值是否相等类型可以不同,类型不同时,使用Number()转换成Number类型在进行判断。例外规则,null==undefined,null/undefined进行运算时不进行隐式类型转换。通常把值转为Boolean值,进行条件判断。Boolean(null)===Boolean(undefined)>false===false 结果为true
     

4.3  if语句和逻辑运算

在这里插入图片描述

常见的falsely变量(除此之外全是truly变量)。

在这里插入图片描述

总结:

所有基本类型中Boolean值是false的只有6个,分别是 : 0 NaN ' ' null undefined false
引用类型Boolean值全是true.

4.4 if语句中的判断

在这里插入图片描述

总结:

if条件是单个值时,如果是truly值,条件成立, 如果是falsely值,条件不成立

逻辑判断:

在这里插入图片描述

总结:

  • 逻辑与(&&)运算规则: 左侧为truly返回右侧,左侧为fasely返回左侧。
  • 逻辑或( | | )运算规则: 左侧为truley返回左侧,左侧为fasely返回右侧。

ES6新的数据类型Symbol

  • ES6 引入了一种新的原始数据类型Symbol,表示独一无二的值。它是 JavaScript
  • 语言的第七种数据类型,前六种是:undefined、null、布尔值(Boolean)、字符串(String)、数值(Number)、对象(Object)。
  • Symbol 值通过Symbol函数生成。这就是说,对象的属性名现在可以有两种类型,一种是原来就有的字符串,另一种就是新增的 Symbol
  • 类型。凡是属性名属于 Symbol 类型,就都是独一无二的,可以保证不会与其他属性名产生冲突
  • Symbol 值通过Symbol函数生成。这就是说,对象的属性名现在可以有两种类型,一种是原来就有的字符串,另一种就是新增的 Symbol
  • 类型。凡是属性名属于 Symbol 类型,就都是独一无二的,可以保证不会与其他属性名产生冲突

应用场景

作为对象的属性名

{
    let a1=Symbol.for('abc')
    let obj={
        [a1]:'123',//参考api中对象的扩展部分中属性名表达式,这里[a1]代表变量a1的key
        'abc':'123',
        'c':456
    }
    console.log('obj',obj)
}
打印结果为

{abc: "123", c: 456, Symbol(abc): "123"}

可以看到两个abc是不冲突的

注意:

常规的for in,let of的方式去取 ,比如Object.entries,Object.keys,是拿不到symbol的值

  for(let [key,value] of Object.entries(obj)){
        console.log('let of',key,value)
    }
结果为

let of abc 123let of c 456

解决方案是

1)使用Object.getOwnPropertySymbols(obj) 。这种方式只拿到了symbol的变量的值

    Object.getOwnPropertySymbols(obj).forEach(function(item){
        console.log(obj[item])
    })
结果为

123

2)使用Reflect.ownKeys(obj)

Reflect.ownKeys(obj).forEach(function(item){
        console.log(obj[item])
    })
结果为

123
456
123
 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript数据类型包括字符串(String)、数字(Number)、布尔(Boolean)、对象(Object)、数组(Array)、空值(Undefined)和空引用(Null)等。\[1\]在JavaScript中,字符串是由一系列字符组成的,可以使用单引号或双引号表示。对象是一种复合数据类型,可以包含多个键值对。数组是一种特殊的对象,它以数字作为索引,存储多个值。数字可以是整数或浮点数,布尔值只有两个取值,即true和false。空值表示变量没有被赋值,而空引用表示变量的值为null,表示空对象。\[2\]在JavaScript中,可以通过typeof运算符来检测数据类型。此外,还可以通过拼接空字符串、使用toString()方法或拼接带参数的字符串来将数值型转化为字符串型。\[3\] #### 引用[.reference_title] - *1* [JavaScript数据类型](https://blog.csdn.net/huishi__/article/details/123454041)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [JavaScript 学习手册二:JS 数据类型](https://blog.csdn.net/weixin_54327001/article/details/121964883)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [JavaScript的七种数据类型](https://blog.csdn.net/Zhang_wang_yun/article/details/129959316)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值