JS里的数据类型

本篇文章将简要地讲述关于Javascript数据类型的一些知识,文章中仅挑选不同数据类型的一些个人认为容易在平时出错的,或者值得记忆的知识点,详细内容可查看阮一峰老师编写的《JavaScript标准参考教程》

Javascript里共有七种数据类型,分别为数值(number)、字符串(string)、符号(symbol)、布尔(boolean)、对象(object)、null、undefined,下面将一一讲述和他们有关的知识点

1.数值(number)

在JavaScript 内部,所有数字都是以64位浮点数形式储存,即使整数也是如此。
一个浮点数由一个64位的二进制数来表示,其中,

二进制数中对应位数的含义如下:

第1位:符号位,0表示正数,1表示负数
第2位到第12位(共11位):指数部分
第13位到第64位(共52位):小数部分(即有效数字)

小数部分确认小数精度,最高精度为15位,也就是说Javascript可以对精度为15位的十进制数进行精确处理,而指数部分表示整数大小的范围为:2-1023<x<21024

而关于数值的进制问题,总结如下:

十进制:没有前导0的数值。
八进制:有前缀0o或0O的数值,或者有前导0、且只用到0-7的八个阿拉伯数字的数值。
十六进制:有前缀0x或0X的数值。
二进制:有前缀0b或0B的数值。

parseInt

parseInt可以将字符串转化为整数
parseInt(x,y),其中x表示要转换的字符串,y表示字符串的进制数,默认为10,可取范围为2~36,小于或者超出范围则返回NaN,若y值为0、null和undefined则直接忽略
由于parseInt会强制地先把第一个参数转变为字符串,再将这个字符串译成其他进制的数值,因此会出现下述情况:

parseInt(0x11,36) //43
parseInt(0x11,2) //1

//等同于
parseInt(string(0x11),36) 
parseInt(string(0x11),2)

//即
parseInt('17',36)
parseInt('17',2)


两个特殊的数值NaN和Infinity

NaN是数值,表示非数字,且有性质:
NaN!=NaN //可用于判断一个值是否为NaN
Infinity大于一切数值(除了NaN),Infinity小于一切数值(除了NaN)
Infinity具有以下特殊性质:

0*Infinity //NaN
Infinity-Infinity //NaN
Infinity/Infinity //NaN


2.字符串(string)

反斜杠的作用

(1)用于转义,主要有下面这些:

\0 :null(\u0000)
\b :后退键(\u0008)
\f :换页符(\u000C)
\n :换行符(\u000A)
\r :回车键(\u000D)
\t :制表符(\u0009)
\v :垂直制表符(\u000B)
' :单引号(\u0027)
" :双引号(\u0022)
\ :反斜杠(\u005C)

(2)可以通过使用反斜杠来换行,不过值得注意的是,反斜杠换行的话,反斜杠后不得出现空格,否则会报错,报错原因是因为反斜杠转义了后面的空格

3.符号(symbol)



4.布尔(boolean)

布尔有两个值,一个为真(true),一个为假(false)。

5.null和undefined

之所以把null和undefined放在一起讲,是因为这两种数据类型都表示“没有”,在含义上非常相似,若要说这两种数据类型的区别,可总结为以下两点:
1.一个变量若没有赋值,那么他的值就为undefined,这是语法上规定的。
2.若有一个对象(object),现在不想给值给这个对象,推荐给null来表示这个是空对象。这是程序员的惯例。

6.对象(object)

一个对象简单来说就是一个哈希表,对象里面是一组“键值对”(key-value)的集合,是一种无序的复合数据集合。对象是一种复杂的数据类型,它是由许多简单的数据类型组成的。

创建对象的三种方式:

var o1={}
var o2=new Object()
var o3=Object.create(Object prototype)



在对象中,对象属性左边的key永远是字符串,即使没有写单引号,实际上它代表的也是字符串。
对象的属性中,key可以是空字符串,空字符串作为key也是可以使用的,是成立的。
但是要注意下面两种情况的区分:

var obj={9a:'frank'} //报错
var obj={a b:'frank'} //报错
//区分
var obj={'9a':'frank'} //成立
var obj={'a b':'frank'} //成立

如果一个对象的key符合标识符的话,person['name']可以写成person.name

区分delete的用法

//(1)
delete person['name']
person .name //undefined (无value)
'name' in person //false (无key)

//区分(2)
person['name']=undefined
person.name //undefined(无value)
'name' in person //true(有key)


遍历对象属性

for (var key in person) {
    console.log(key) //key的输出顺序看运气,不一定按照对象内属性的顺序输出
}

注意,区分遍历时key与对象里key属性的不同,下面为错误代码示范:

for (var key in person) {
    console.log(person.key) //错误,key为变量,非person内的key属性,因此此处应该为console.log(person[key])
}


最后,提及一下JavaScript的两个BUG

typeof null // 'object' 实际应该'null'

typeof function() {} //'funciton' 实际应为'object'




本教程版权归宣泽彬所有,转载须说明来源

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,045评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,114评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 147,120评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,902评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,828评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,132评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,590评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,258评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,408评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,335评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,385评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,068评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,660评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,747评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,967评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,406评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,970评论 2 341

推荐阅读更多精彩内容