JS里的数据类型

七种数据类型:分别是数值(number),字符串(string) ,布尔(boolean),对象(object),null,undefined,symbol

1 数值:

整数与浮点数:js里面的数字全部都是小数没有整数概念,涉及小数运算要格外小心
数值精度
浮点数由64个二进制数组成

(-1)^符号位 * 1.xx...xxx * 2^指数部分

第一位符号位,第2到12(11位)位指数部分,13到64位(52位)小数部分
数值表示方法:
科学计数法表示

123e3 // 123000
123e-3 // 0.123
-3.1E+1 // -31

数值的进制:

  • 十进制:没有前导0的数值
  • 八进制:有前缀00或0o,或者有前导0
  • 十六进制:前缀0x或0X
  • 二进制:前缀0b或0B

注:存数值的时候尽量存字符串(例如存电话号码)

var phonenumber = '0123456'

如果写成数值 0123456则会被当成8进制数

NaN:
含义:表示非数字,主要出现在将字符串解析成数字出错的场合

5 - 'x' // NaN
0/0 // NaN
  • NaN不等于任何值包括他自己
NaN === NaN // false
  • NaN和任何数(包括他自己)运算,得到的都是NaN

字符串

定义:字符串是多个排在一起的字符,放在单引号或双引号之中
单引号内部可以使用双引号,反之也成立

  • 空字符串:‘’ “”(长度为0)
  • 空格字符串: ‘ ’ “ ”(长度为1)

方法1: 字符串默认只能写在一行,如果长字符串想分成多行,可以每行尾部加反斜杠

var six = 'dkjjdj \
llkkk\
sdjkkl\'

注:这是一个Bug语法,要求反斜杠后面必须是换行符,如果有人加了空格(\ ),则空格会被反斜杠转义,所以不推荐这个写法,推荐方法2
方法2:用加号连接

var six = 'abd' +     
       'ahhjk' +
            'skdfh'

2 转义:
反斜杠( \ )被用来当作转义符

  • ' :单引号
  • \ :反斜杠
  • \n :回车
  • \t :制表符(Tab)
    (这些转义符的长度都是1)

JS允许直接在程序中使用Unicode码表示字符,将字符写成/uxxxx的形式

var s= '\u00A9'
s // "®"

var f\u006F\u006F = 'abc'
foo // "abc"

码点在U+10000到U+10FFFF之间的字符,JS把他们都当成两个字符(length为2)
也就是说JS返回的字符串长度可能是不正确的。

3 Base64转码
Base64就是一种编码方式,可以将任意值转成0到9,A到Z,a到z, + 和 /这64个字符组成的可打印的字符。使用的主要目的,是为了不出现特殊字符,简化程序处理。

  • btoa() : 任意值转为Base64编码
  • atob() : Base64编码转为原来的值

对象

对象(哈希表),是一组键值对(key-value)的集合,是一种无序的复合数据类型(由其他类型组合而成)

1,创建对象
对象以" { " 开头,以" } "结尾,左边键名永远是字符串,两个键值之间用逗号隔开

var obj ={
  name:'Eskimo',
  gender :'male'
}

var o1 ={}
var o2 =new object()
var o3 =Object.create(Object.prototype)  //三种方法生成一个新对象

2,键名:
所有的键名都是字符串,可以不加引号但是有条件
当键名满足标志符规则(不能以数字开头,不能含有空格)可以不加引号,否则会报错

var obj ={
    1p:'Eskimo'
} // 报错

var obj={
    '1p': 'Eskimo'
}  //不报错  (不符合标志符规则要加引号)

对象的每一个键名又称“属性”(property)键值可以是任何数据类型,如果一个属性的值是一个函数,那么把这个属性叫做“方法” ,可以像函数一样调用

var obj ={
    name:function(x){
          console.log(x)
    }
}
obj.name(Eskimo)    //Eskimo
  • 属性可以动态创建,不需要在刚开始就写好
var obj ={}
obj.name ='Eskimo'
obj.gender =male

3 ,属性的读取
读取属性有两种方法,一种是使用点运算符,还有一种是使用方括号运算符

var obj ={
    name: 'Eskimo',
    gender :'male'
}
var gender=‘name’
obj.name // "Eskimo"     (点运算符后面接的name仍是字符串)
obj['gender'] // "male"    (方括号里面的引号不能省略)
obj[gender]  //"Eskimo"  (方括号里面如果不使用引号则视为一个变量)

如果数值是键名则不能用点运算符(会被当成小数)

var obj ={
    123: 'hello'
}
obj.123 //  报错
obj[123] // 'hello'

4,属性的查看
API : Object.keys

 Object.keys(obj) //   ['name','gender']

5,属性的删除:delete

delete obj['name']   // 删除一个key
obj.name   //  undefined  (无value )
'name' in obj  //false   (无key)

区别于

obj['name'] = undefined
'name' in obj   // true (有key无value)

6,属性的遍历:for....in循环

var obj ={
    name:'Eskimo'
    age:'18'
    key: 3
}
for(var key in person){
      console.log(obj[key])   // "Eskimo" "18" "3"
      console.log(obj.key)   //  3
      console.log(obj['key']) //  3
}

null和undefined

  • 如果变量没有值------undefined (非对象)
  • 如果有一个对象object,现在不想给值-------null

symbol

https://zhuanlan.zhihu.com/p/22652486

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

推荐阅读更多精彩内容

  • 简介 JavaScript 语言的每一个值,都属于某一种数据类型。JavaScript 的数据类型,共有七种。 n...
    sxfshdf阅读 885评论 0 48
  • 1. 七种数据类型 number 数值 :整数和小数 string字符串 : 文本 boolean布尔值 :tru...
    加油吧_阅读 148评论 0 0
  • JavaScript 语言的每一个值,都属于某一种数据类型。JavaScript 的数据类型,共有六种。 数值(n...
    七月凛冬阅读 399评论 0 0
  • 目录 概述typeof运算符number(数字)string(字符串)boolean(布尔)undefined &...
    阿小经阅读 782评论 0 7
  • 数值(number):整数和小数(比如1和3.14)字符串(string):文本(比如Hello World)。布...
    一只小前端阅读 1,933评论 0 0