JS里的数据类型

作者: 宣泽彬 | 来源:发表于2018-06-04 22:18 被阅读5次

    本篇文章将简要地讲述关于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'
    



    本教程版权归饥人谷_宣泽彬和饥人谷所有,转载须说明来源

    相关文章

      网友评论

        本文标题:JS里的数据类型

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