JS之数据类型

一、数据类型分类

1. number数字

数值表示

  • 十进制:75 = 75
  • 二进制(前缀0b或0B): 0b10 = 2
  • 八进制(前缀0o或00,或者前导0且只用到0-7八个阿拉伯数字的数值): 017 = 15
  • 十六进制(前缀0x或0X): 0x2F = 47
  • 科学计数法: 1.23e2 = 123

浮点数

JavaScript 内部,所有数字都是以64位浮点数形式储存,即使整数也是如此。这就是说,JavaScript 语言的底层根本没有整数,所有数字都是小数(64位浮点数)。

浮点数表示:(-1)^符号位 * 1.xx...xx * 2^指数部分

由于浮点数不是精确的值,涉及小数的比较和运算要特别小心。

64位浮点数的指数部分的长度是11个二进制位,意味着指数部分的最大值是2047(2的11次方减1)。分出一半表示负数,则一个数大于等于2的1024次方,那么就会发生“正向溢出”,返回Infinity,一个数小于等于2的-1075次方(指数部分最小值-1023,再加上小数部分的52位),那么就会发生为“负向溢出”,返回0。

Math.pow(2, 1024) // Infinity
Math.pow(2, -1075) // 0

科学计数法

以下两种情况,JavaScript 会自动将数值转为科学计数法表示,其他情况都采用字面形式直接表示。

(1)小数点前的数字多于21位。

(2)小数点后的零多于5个。

1234567890123456789012
// 1.2345678901234568e+21

0.0000003 // 3e-7

2. string字符串

字符串就是零个或多个排在一起的字符,放在单引号或双引号之中。

  • 空字符串:''或"",length==0

  • 空格字符串:' '或" ",length==1

  • 多行字符串:以反引号(`)包裹

    var s = `1234
    6789`
    

    或在每一行的尾部使用反斜杠

    var longString = 'Long \
    long \
    long \
    string';
    
    longString // "Long long long string"
    
  • 字符串转义:

    • \0 :null(\u0000
    • \b :后退键(\u0008
    • \f :换页符(\u000C
    • \n :换行符(\u000A
    • \r :回车键(\u000D
    • \t :制表符(\u0009
    • \v :垂直制表符(\u000B
    • \' :单引号(\u0027
    • \" :双引号(\u0022
    • \\ :反斜杠(\u005C
    • \uXXXX\u后面紧跟四个十六进制数(0000FFFF),代表一个字符

3.boolean布尔值

布尔值只有“真”true和“假”false两个状态。

下列运算符会返回布尔值:

  • 前置逻辑运算符: ! (Not)
  • 两元逻辑运算符: && (And),|| (Or)
  • 相等运算符:===!====!=
  • 比较运算符:>>=<<=

如果 JavaScript 预期某个位置应该是布尔值,会将该位置上现有的值自动转为布尔值。转换规则是除了下面六个值被转为false,其他值都视为true

undefinednullfalse0NaN""''(空字符串)

4. undefined

undefined是一个表示"此处无定义"的原始值,转为数值时为NaN

5. null空值

``null是一个表示“空”的对象,转为数值时为0`

6.Object对象

对象就是一组“键值对”(key-value)的集合,是一种无序的复合数据集合。

function和array也是对象的一种,是特殊的对象。

键名

对象的所有键名都是字符串,所以加不加引号都可以。如果键名是数值,会被自动转为字符串。

如果键名不符合标识名的条件(比如第一个字符为数字,或者含有空格或运算符),且也不是数字,则必须加上引号,否则会报错。

键值

可以是任何数据类型,对象的键名叫做‘属性’,键值可以是函数。

操作对象

使用对象名['属性名']或对象名. 属性名进行调用。

var obj = {
  123: 'hello world'
};

obj.123 // 报错
obj[123] // "hello world"
obj['123'] // "hello world"

in

in运算符用于检查对象是否包含某个属性(键名),但不能识别哪些属性是对象自身的,哪些属性是继承的。

for...in

for...in循环用来遍历一个对象的全部属性。

  • 它遍历的是对象所有可遍历的属性,会跳过不可遍历的属性。
  • 它不仅遍历对象自身的属性,还遍历继承的属性。

7. symbol符号(ES6新增)

二、数据类型检验

typeof 3.14 // 'number'
typeof Infinity // 'number'
typeof NaN // 'number'

typeof "" // 'string'
typeof "123bla" // 'string'

typeof true // 'boolean'

typeof undefined // 'undefined'
typeof undeclaredVariable // 'undefined'

typeof {a:1} // 'object'
typeof [1, 2, 4] // 'object'
typeof new Date() // 'object'
typeof null // "object"(特别注意)

typeof function(){} // 'function'(特别注意)
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 5种简单数据类型:Undefined、Null、Boolean、Number和String。1种复杂数据类型---...
    fenerchen阅读 2,972评论 0 2
  • JavaScript 的数据类型,共有七种。数值(Number):整数和小数(比如1和3.14)。字符串(Stri...
    手劲很大阅读 3,630评论 0 0
  • 数据类型的判断 JavaScript 有三种方法,可以确定一个值到底是什么类型。 typeof运算符 instan...
    kiterumer阅读 3,177评论 0 0
  • 简介 PHP 支持 8 种原始数据类型。 四种标量类型: boolean(布尔型)/ integer(整型) / ...
    零一间阅读 3,860评论 0 0
  • 基本数据类型:Undefined、Null、Boolean、String、Number、Symbol 复杂数据类型...
    晴天的晴q阅读 1,306评论 0 1

友情链接更多精彩内容