一文带你走进js数据类型与数据结构的世界
目录
- 1. 什么叫动态类型
- 2. 数据类型
- 2.1 原始类型(6 种原始类型,使用 typeof 运算符检查)
- 2.2 null 与 Object
- 3. 原始值
- 3.1 原始值基本概念
- 3.2 各类型说明
1. 什么叫动态类型
- JavaScript 是一种弱类型或者说动态语言。
- 我们不用提前声明变量的类型,在程序运行过程中,类型会被自动确定。
- 这也意味着你可以使用同一个变量保存不同类型的数据
let a; // 初始不给任何类型a = 11; // a此时是number类型a = "二大爷"; // a 变成了字符串类型a = true; // a 变成了布尔类型
实际应用过程中并不推荐这样做,容易出现一些不可预知的错误
- 比如你兄弟忽然变成了女的,又很漂亮(睡还是不睡?)
- 比如你闺蜜忽然变成了男的,很帅(上还是不上?)
- 比如隔壁老王变成了你老婆…(老王自己变成绿帽?)
- …
- 综上所述,数据类型一旦被确定,不要轻易篡改~~
文章图片
2. 数据类型
- 你可能仍然以为JavaScript只有 6 种数据类型(这就是固有认知)
- 最新的 ECMAScript 标准定义了 8 种数据类型:
2.1 原始类型(6 种原始类型,使用 typeof 运算符检查)
- undefined:typeof instance === “undefined”
- Boolean:typeof instance === “boolean”
- Number:typeof instance === “number”
- String:typeof instance === "string"
- BigInt:typeof instance === “bigint”(任意大的整数)
- Symbol :typeof instance === “symbol”
2.2 null 与 Object
- null: typeof instance === “object”
- typeof instance === “object”。
- 任何 constructed 对象实例的特殊非数据结构类型,也用做数据结构:(new Object,new Array,new Map,new Set,new WeakMap,new WeakSet,new Date),和几乎所有通过 new 关键字创建的东西。
- typeof 操作符的唯一目的就是检查数据类型。
- 如果我们希望检查任何从 Object 派生出来的结构类型,使用 typeof 是不起作用的,因为总是会得到 “object”。
- 检查 Object 种类的合适方式是使用 instanceof 关键字(数组与对象等),但即使这样也存在误差(目前没有百分百准备的方法,很遗憾)
文章图片
3. 原始值 【一文带你走进js数据类型与数据结构的世界】
3.1 原始值基本概念
- 除 Object 以外的所有类型都是不可变的(值本身无法被改变)。
- 例如,与 C 语言不同,JavaScript 中字符串是不可变的(JavaScript 中对字符串的操作一定返回了一个新字符串,原始字符串并没有被改变),我们称这些类型的值为“原始值”。
3.2 各类型说明
- 布尔类型:一个逻辑实体,可以有两个值:true 和 false
- Null类型:只有一个值: null,就是啥也没有
- Undefined类型:一个没有被赋值的变量会有个默认值 undefined
- Number类型:没有像Java一样进一步细分类型,整数和浮点数都可以。还有一些带符号的值:+Infinity,-Infinity 和 NaN (非数值,Not-a-Number)
- BigInt 类型:JavaScript 中的一个基础的数值类型,可以用任意精度表示整数。可以安全地存储和操作大整数,甚至可以超过数字的安全整数限制。BigInt是通过在整数末尾附加 n 或调用构造函数来创建的。
BigInt(value);
value: 创建对象的数值。可以是字符串或者整数
BigInt() 不是构造函数,因此不能使用 new 操作符
- String类型:字符串是不可更改的。这意味着字符串一旦被创建,就不能被修改。但是,可以基于对原始字符串的操作来创建新的字符串。
两个字符串的连接使用连接操作符 (+) 或者 String.concat().
- Symbols类型:唯一的并且是不可修改的, 并且也可以用来作为Object的key的值
- Object类型:对象可以被看作是一组属性的集合,用对象字面量语法来定义一个对象时,会自动初始化一组属性。
以上就是一文带你走进js-数据类型与数据结构的世界的详细内容,更多关于js 数据类型与数据结构的资料请关注脚本之家其它相关文章!
推荐阅读
- 不废话,代码实践带你掌握|不废话,代码实践带你掌握 强缓存、协商缓存!
- 生发知识,带你深入了解
- 走进大师的世界|走进大师的世界 ——《维特根斯坦?传—天才之责任》
- 谭木匠连续举办三届木艺展|谭木匠连续举办三届木艺展 中外大师作品走进南艺校园
- 织网布局,社群营销走进山东玖零落地企业
- 带你了解类型系统以及flow和typescript的基本使用
- 带你来看花
- 从前沿科技到现实应用,人脸识别智能门禁加速走进智慧社区
- 《走进魔法店》读后感|《走进魔法店》读后感 《记承天寺夜游》
- 5|5 个 PPT 常用快捷键带你从此走向高效