集体学习笔记,如有谬误请指出

数据类型

根本数据类型(原始值类型)

  • number NaN/Infinity非凡
  • string 单引号/双引号/反引号``
  • boolean true/false
  • null
  • undefined
  • symbol 创立惟一值
  • bigint

援用数据类型:

  • object

    • {} 一般对象
    • [] 数组对象
    • /^[+-]?(?:\d|(?:[1-9]\d+))(\.\d+)?$/ 正则对象
    • 日期对象
    • function(较为非凡,函数是一个附带可被调用性能的惯例的对象
    • ...

一共8大数据类型

更加具体和官网的解释参考MDN: JavaScript 数据类型和数据结构

留神:
javascript中,setmap是一种数据结构,实质上还是Object类型

typeof

typeof 操作符返回一个字符串,示意未经计算的操作数的类型

//7个根本数据类型typeof 10//"number"typeof '1'//"string"typeof null//"object"typeof undefined//"undefined"typeof Symbol()//"symbol"typeof 9007199254740991n//"bigint"typeof true//"boolean"
//object类型typeof {}//"object"typeof []//"object"typeof /^$///"object"typeof new Date()//"object"

留神比拟非凡的

//须要记住的非凡值typeof NaN//"number"typeof function(){}//"function"typeof null//"object"typeof []//不要搞混,typeof 细分对象是不能够的//"object"

留神三个包装对象

所谓“包装对象”,指的是与数值、字符串、布尔值别离绝对应的NumberStringBoolean三个原生对象。这三个原生对象能够把原始类型的值变成(包装成)对象。
var v1 = new Number(123);var v2 = new String('abc');var v3 = new Boolean(true);typeof v1 // "object"typeof v2 // "object"typeof v3 // "object"v1 === 123 // falsev2 === 'abc' // falsev3 === true // false

typeof null === 'object' 起因

typeof的原理:

  • 所有的数据类型值在计算机中存储的都是依照“二进制”存储的
  • null -> 000000
  • 只有是对象都是以 000 开始的
  • typeof`检测的时候,是依照计算机存储的二进制的值来检测的

MDN解释:

总结:

因为在javascript当中值的类型由类型标签+理论数值示意,对象的类型标签是0,而null指向空指针,用0x00的值来示意,所以null的类型标签也是0,因而typeof null 返回 "object"

NaN

NaN:not a number 不是一个有效数字,然而它属于number数据类型的

console.log(typeof NaN); //=>"number"console.log(NaN == NaN); //=>falseconsole.log(NaN === NaN); //=>falselet n = 10;//如何检测是NaNif (isNaN(n)) {    // 条件成立:证实它真的是非有效数字}Object.is([val1],[val2])//检测两个值是否相等console.log(Object.is(NaN, NaN)); //=>true

Object.is()外部对NaN的判断做了非凡解决

Infinity

typeof Infinity//"number"Infinity===Infinity//true-Infinity===Infinity//false

symbol

简略介绍

JS 中的 Symbol 是什么?
ECMAScript 6入门-Symbol

Symbol 能够创立一个举世无双的值。
console.log(new Symbol()); //Uncaught TypeError: Symbol is not a constructor//无奈应用new Sumbol(根本数据类型)console.log(Symbol('AA') === Symbol('AA')); //false//每次都会创立一个惟一值,括号中的字符串能够看做标记,正文,只是为了辨别let symb = Symbol('BB');console.log(symb === symb); //true 

bigint

最大平安数与最小平安数

Number.MAX_SAFE_INTEGER//9007199254740991Number.MIN_SAFE_INTEGER//-9007199254740991Math.pow(2,53)//9007199254740992

超过这个数计算会呈现谬误

bigint解决大数问题

如果服务器存储ID是长整型,int值十分大。当服务器将其转化为字符串的时候,返回给客户端就没有问题,如果服务器以Number类型返回,那么这个返回的id在浏览器中和服务器中值不一样,会产生扭转,呈现谬误

为了解决这个问题,在es6中引入新的数据类型bigint,在数字前面加n即为bigint类型

9007199254740992123n+1n//9007199254740992124ntypeof 9007199254740992124n//"bigint"