前端进阶系列(第1期):理解JavaScript数据类型

栏目: JavaScript · 发布时间: 5年前

内容简介:前端进阶系列本着“好好干前端”的心态,一步一个脚印认真练好前端的基本功,为在前端的发展道路上做好铺垫。本周正式开始前端进阶的第1期,本周的主题是最新的 ECMAScript 标准定义了7种数据类型,主要分为两大类

前端进阶系列本着“好好干前端”的心态,一步一个脚印认真练好前端的基本功,为在前端的发展道路上做好铺垫。

本周正式开始前端进阶的第1期,本周的主题是 理解JavaScript数据类型

数据类型

最新的 ECMAScript 标准定义了7种数据类型,主要分为两大类 基本类型引用类型

基本类型

基本类型 有时也被称为 值类型原始类型 。其中包括6种数据类型,分别是: 字符串类型(String)数字类型(Number)布尔类型(Boolean)对空类型(Null)未定义类型(Undefined)符号类型(Symbol)

字符串类型

JavaScript的字符串类型用于表示文本数据。它是一组16位的无符号整数值的“元素”。在字符串中的每个元素占据了字符串的位置。第一个元素的索引为0,下一个是索引1,依此类推。字符串的长度是它的元素的数量。

数字类型

根据 ECMAScript 标准,JavaScript 中只有一种数字类型:基于 IEEE 754 标准的双精度 64 位二进制格式的值(-(263 -1) 到 263 -1)。它并没有为整数给出一种特定的类型。除了能够表示浮点数外,还有一些带符号的值:+Infinity,-Infinity 和 NaN (非数值,Not-a-Number)。

123; // 正整数
-123; // 负整数
520.1314; // 浮点数
0; // 零
Infinity; // 正无穷
-Infinity; // 负无穷
typeof Infinity; // number
复制代码

布尔类型

布尔表示一个逻辑实体,可以有两个值:true 和 false。

2 > 1; // true
[] == []; // false 
[] == ![]; // true 这是为什么?
null == undefined // true
'10' > '3'; // flase 这个啥?
typeof true; // boolean
复制代码

Null 类型

Null 类型只有一个值: null。

null === null; // true
typeof null; // object 为什么不是 null呢?
复制代码

Undefined 类型

一个没有被赋值的变量会有个默认值 undefined。

let a; // 我申明我是一个变量 a
typeof a; // undefined 申明未赋值
undefined == undefined; // true
undefined == 0; // false
undefined == null; // true
undefined == ''; // false
复制代码

符号类型

符号(Symbols)是ECMAScript 第6版新定义的。符号类型是唯一的并且是不可修改的, 并且也可以用来作为Object的key的值。

let obj = {};
let symbol1 = Symbol();
let symbol2 = Symbol();

typeof symbol1; // symbol
typeof symbol2; // symbol

symbol1 == symbol2; // false

obj.symbol1 = 'hello';
obj[symbol1] = 'world';

console.log(obj.symbol1 + ' ' + obj[symbol1]); // hello world

复制代码

引用类型

引用类型 主是指 Object类型

Object 对象

在计算机科学中, 对象是指内存中的可以被 标识符 引用的一块区域。

let obj1 = {}; // 对象字面量
let obj2 = new Object(); // 实例化一个对象

typeof obj1; // object
typeof obj2; // object

const person = { author: {name: "布一", "wechat": "Hankewins"}, 1: "No.1" };

console.log(person.author.name); // 布一
console.log(person.author.wechat); // Hankewins
console.log(person[1]); // No.1
复制代码

类型对比

我们都知道JavaScript中有两大数据类型: 基本类型引用类型 ,其中 基本类型 主要是把值存储在 栈内存 中,而 引用类型 却是把地址存储在 栈内存 中,把值存储在 堆内存 中,然后将 栈内存 中存储的地址指向 堆内存 中存储的值。

基本类型 数据结构 存储位置
基本类型 数字、字符串、布尔、Null、Undefined、Symbol
引用类型 数组、对象、函数 栈、堆

什么是堆栈?

堆栈是两种数据结构,是一种数据项按序排列的数据结构,只能在一端进行插入和删除操作。堆为队列优先,先进先出(FIFO)。栈为先进后出(FILO)。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

TCP/IP详解 卷1:协议

TCP/IP详解 卷1:协议

W.Richard Stevens / 范建华 / 机械工业出版社 / 2000-4-1 / 45.00元

《TCP/IP详解卷1:协议》是一本完整而详细的TCP/IP协议指南。描述了属于每一层的各个协议以及它们如何在不同操作系统中运行。作者W.Richard Stevens用Lawrence Berkeley实验室的tcpdump程序来捕获不同操作系统和TCP/IP实现之间传输的不同分组。对tcpdump输出的研究可以帮助理解不同协议如何工作。 《TCP/IP详解卷1:协议》适合作为计算机专业学......一起来看看 《TCP/IP详解 卷1:协议》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

随机密码生成器
随机密码生成器

多种字符组合密码

SHA 加密
SHA 加密

SHA 加密工具