带你读《现代Javascript高级教程》六、Javascript数据类型和类型转换(1)

简介: 带你读《现代Javascript高级教程》六、Javascript数据类型和类型转换(1)

六、Javascript数据类型和类型转换

在JavaScript中,理解数据类型,如何区分它们,以及它们如何被转换是至关重要的。在这篇文章中,我们将探讨这些主题,以帮助巩固你的JavaScript基础。

1.基础数据类型和引用数据类型

当涉及JavaScript的数据类型时,我们可以将其分为两类:基本数据类型和引用数据类型。

1基本数据类型(Primitive Types):

  • 数字(Number):表示数值,可以包含整数和浮点数。例如:let age = 25;
  • 字符串(String):表示文本数据,由一串字符组成。可以使用单引号或双引号包裹。例如:let name = 'John';
  • 布尔(Boolean):表示逻辑值,只有两个可能的值:true(真)和false(假)。例如:let isStudent = true;
  • 空值(Null):表示空值或无值。它是一个特殊的关键字null。例如:let myVariable = null;
  • 未定义(Undefined):表示变量声明但未赋值的值。它是一个特殊的关键字undefined。例如:let myVariable;
  • 符号(Symbol):表示唯一且不可变的值,用于创建对象属性的唯一标识符。在ES6中引入。例如let id = Symbol('id');

2引用数据类型(Reference Types):

  • 对象(Object):表示复杂的数据结构,可以包含多个键值对。对象可以通过大括号{}创建,或者通过构造函数创建。例如:

 

let person = {
  name: 'John',
  age: 25,
  city: 'New York'};

 

  • 数组(Array):表示有序的数据集合,可以包含任意类型的数据。数组可以通过方括号[]创建。例如:
let numbers = [1, 2, 3, 4, 5];

 

  • 函数(Function):是一段可执行的代码块,可以接收参数并返回值。函数可以作为变量、参数传递、存储在对象属性中等。例如:
function greet(name) {
  console.log('Hello, ' + name + '!');}

 

基本数据类型在JavaScript中是按值传递的,而引用数据类型则是按引用传递的。这意味着基本数据类型的值在传递过程中是复制的,而引用数据类型的值在传递过程中是共享的。

 

了解这些基本数据类型和引用数据类型,为后续讲解类型转换提供了基本的背景知识。它们在JavaScript中的不同行为和用法对于理解类型转换的概念和机制非常重要。

  1. 使用typeof操作符

在JavaScript中,我们可以使用typeof操作符来获取一个值的数据类型。下面是一些例子:

console.log(typeof undefined);  // 'undefined'
console.log(typeof true);  // 'boolean'
console.log(typeof 78);  // 'number'
console.log(typeof 'hey');  // 'string'
console.log(typeof Symbol());  // 'symbol'
console.log(typeof BigInt(1));  // 'bigint'
console.log(typeof new String('abc'));  // 'object'
console.log(typeof null);  // 'object'
console.log(typeof function(){});  // 'function'
console.log(typeof {name: 'Jack'});  // 'object'

 

注意,typeof返回的是值的类型,而不是变量的类型。因为在JavaScript中,变量本身并没有类型,它们可以持有任何类型的值。

 

对大多数对象使用typeof时,返回的结果是'object',对于函数则返回'function'。特别的,对null使用typeof返回的也是'object',这是一个历史遗留的bug,我们无法改正。

所以,如果我们需要检查一个值是否为null,我们可以使用以下方式:

var a = null;
console.log(!a && typeof a === "object"); // true


带你读《现代Javascript高级教程》六、Javascript数据类型和类型转换(2)https://developer.aliyun.com/article/1349669?groupCode=tech_library

相关文章
|
2月前
|
存储 JavaScript 对象存储
js检测数据类型有那些方法
js检测数据类型有那些方法
136 59
|
18天前
|
存储 JavaScript 前端开发
JavaScript 数据类型详解:基本类型与引用类型的区别及其检测方法
JavaScript 数据类型分为基本数据类型和引用数据类型。基本数据类型(如 string、number 等)具有不可变性,按值访问,存储在栈内存中。引用数据类型(如 Object、Array 等)存储在堆内存中,按引用访问,值是可变的。本文深入探讨了这两种数据类型的特性、存储方式、以及检测数据类型的两种常用方法——typeof 和 instanceof,帮助开发者更好地理解 JavaScript 内存模型和类型检测机制。
38 0
JavaScript 数据类型详解:基本类型与引用类型的区别及其检测方法
|
24天前
|
JavaScript 前端开发
js教程——函数
js教程——函数
21 4
|
30天前
|
JavaScript 前端开发 开发者
【干货拿走】JavaScript中最全的数据类型判断方法!!!!
【干货拿走】JavaScript中最全的数据类型判断方法!!!!
19 1
|
18天前
|
JavaScript 前端开发 安全
如何处理 JavaScript 中的类型转换错误?
【10月更文挑战第9天】处理类型转换错误需要综合运用多种方法和策略,同时要保持对潜在问题的警惕性。通过合理的错误处理,可以提高程序的健壮性,减少因类型转换错误带来的负面影响。
11 0
|
18天前
|
JavaScript 前端开发
JS隐式类型转换规则
【10月更文挑战第9天】 不同的 JavaScript 引擎可能在隐式类型转换的具体实现上存在一些细微差别。理解这些隐式类型转换规则对于正确处理数据和避免错误非常重要。
15 0
|
19天前
|
存储 JavaScript 前端开发
JavaScript数据类型全解:编写通用函数,精准判断各种数据类型
JavaScript数据类型全解:编写通用函数,精准判断各种数据类型
14 0
|
2月前
|
存储 前端开发 JavaScript
前端基础(三)_JavaScript数据类型(基本数据类型、复杂数据类型)
本文详细介绍了JavaScript中的数据类型,包括基本数据类型(Number、String、Boolean、Undefined、Null)和复杂数据类型(Object),并解释了如何使用`typeof`操作符来识别变量的数据类型。同时,还讨论了对象、函数和数组等复杂数据类型的使用方式。
38 2
|
2月前
|
JavaScript 前端开发
JavaScript基础知识-基本数据类型和引用数据类型
关于JavaScript基础知识的文章,主要介绍了基本数据类型和引用数据类型。
38 2
JavaScript基础知识-基本数据类型和引用数据类型
|
30天前
|
JavaScript 前端开发 Java
Node.js 教程
10月更文挑战第1天
37 0