编程笔记 html5&css&js 065 JavaScript 数据类型

简介: 编程笔记 html5&css&js 065 JavaScript 数据类型


数据类型是编程语言的基本构成,不同的编程语言的数据类型有很大区别。数据是程序的处理对象,所以,数据类型的知识要熟练掌握才行。

一、JavaScript 数据类型

  1. Number(数值型):
  • JavaScript 中的数字可以是整数或浮点数。
  • 示例:
let age = 25; // 整数
let pi = 3.14159; // 浮点数
let e = Number.EPSILON; // 极小的正数,表示浮点数精度范围
let infinity = Infinity; // 正无穷大
let nan = NaN; // 非数字(Not a Number),用于表示计算结果无法表示为数字时的结果
  1. String(字符串型):
  • 字符串是由零个或多个字符组成的有序序列,用单引号 ' 或双引号 " 包围。
  • 示例:
let name = 'Aniu'; // 单引号定义字符串
let greeting = "Hello, World!"; // 双引号定义字符串
let multiLineStr = `This is a 
                     multi-line string`; // ES6 中的模板字面量(Template literal)
  1. Boolean(布尔型):
  • 表示逻辑值,仅有两个可能的取值:truefalse
  • 示例:
let isStudent = true;
let hasPassed = false;
  1. Undefined(未定义型):
  • 当变量声明但未初始化时,其值默认为 undefined
  • 示例:
let age;
console.log(age); // 输出: undefined
  1. Null(空对象型):
  • null 是一个特殊的值,表示“无”或者“空对象引用”,它与 undefined 类似但不完全相同,在某些情况下用于显式地表示空值或没有对象值的情况。
  • 示例:
let obj = null; // 显示对象为空
  1. Symbol(符号型):
  • 自从 ECMAScript 6 (ES6) 引入以来,Symbol 是一种原始数据类型,每个 Symbol 值都是唯一的,不可变的,并且不能与其他类型的值进行比较。
  • 示例:
let sym = Symbol("description"); // 创建一个symbol值
  1. BigInt(大整数型):
  • BigInt 是从 ECMAScript 2020 开始支持的数据类型,用于表示超过 Number 类型安全整数范围(-2^53 to 2^53 - 1)的大整数。
  • 示例:
let largeNum = 123456789012345678901234567890n; // 后缀n表示BigInt类型
  1. Object(对象型):
  • 虽然不是基本数据类型,但它是 JavaScript 中的一个重要类型。所有非原始值都是对象,包括数组、函数、日期等。
  • 示例:
let person = { // 对象字面量
  name: "Aniu",
  age: 25,
  sayHello: function() {
    console.log(`Hi, I'm ${this.name}`);
  }
};

以上就是 JavaScript 的八种数据类型,前六种是基本数据类型(原始值),后两种(ObjectFunction,此处未提及 Function,但其实也是对象的一种)属于复杂数据类型(引用类型)。

二、JavaScrip 数据类型分类:

原始值(Primitive values)和引用值(Reference values)。

  1. 原始数据类型(Primitive data types)
    原始数据类型是不可变的,它们直接包含值本身而不是对象的引用。共有六种原始数据类型:
    Undefined: 当变量被声明但未赋值时,其值为 undefined。
    Null: 类型只有一个值 null,它表示一个空或者无指向的对象引用。
    Boolean: 有两种可能的值 true 和 false,用于逻辑判断。
    Number: 表示整数或浮点数,包括正负Infinity和NaN(非数字)。
    String: 由零个或多个16位Unicode字符组成的文本序列,用单引号 ’ 或双引号 " 括起来。
    BigInt: ECMAScript 2020 引入的新类型,用来表示大于Number.MAX_SAFE_INTEGER的整数,使用 n 后缀表示,例如 9007199254740991n。
  2. 复杂数据类型 / 对象数据类型(Object data type)
    Object: 这是一种复杂的数据类型,可以存储任意类型的键值对集合,包括函数、数组和其他对象。所有非原始类型的值都是对象,比如:
    Array: 有序的元素列表,可以通过索引访问元素,如 var arr = [1, ‘two’, true]。
    Function: 函数是可执行的对象,可以看作是一段代码的封装。
    Date: 表示日期和时间的值。
    RegExp: 正则表达式对象,用于文本匹配和搜索操作。
    Map、Set、WeakMap、WeakSet: 集合数据结构。
    Symbol: ECMAScript 6 引入的一种新的原始数据类型,用于创建唯一的标识符。
    typeof 操作符
    typeof 是一个一元操作符,它可以返回变量或表达式的类型。对于以上提到的原始类型(除 null 外),typeof 返回的是正确的类型字符串;而对于 null,typeof null 返回的是 “object”,这是一个历史遗留的bug而非预期行为;对于对象类型,typeof 会返回 “object”,但对于具体的不同对象类型(如函数、数组等),需要使用更精确的方法来检测,如 Array.isArray() 或 instanceof 操作符。
    数据复制与比较
    原始类型在复制时是值复制,即两个变量如果具有相同的原始值,则被认为是相等的。而对象类型(包括数组、函数等)复制时是引用复制,意味着复制得到的新变量只是指向同一个内存地址,修改其中一个变量会影响到另一个变量的值。当比较两个对象类型变量时,即使内容相同,只要不是同一块内存空间,它们之间也会被视为不相等。若要比较对象内容是否相等,通常需要自行实现深度比较方法或使用lodash等库提供的工具函数。

三、JavaScript 数据类型与其他语言的主要区别

  1. 动态类型
  • JavaScript 是一种动态类型语言,这意味着变量在声明时无需指定其数据类型,而且可以在运行时更改其值的数据类型。
  • 相比之下,像 Java、C++、C# 等静态类型语言要求在编译阶段就需要明确变量的类型,并且在程序执行过程中不能改变。
  1. 弱类型
  • JavaScript 具有弱类型的特点,允许不同类型的数据之间进行隐式转换(如字符串和数字相加时,JavaScript 会尝试将字符串转换为数字)。
  • 强类型语言如 C 语言则不会自动进行这种类型的隐式转换,如果不同类型间操作未显式转换,编译器通常会报错。
  1. Object 类型特殊性
  • 在 JavaScript 中,对象是一种复杂数据类型,它可以容纳任何类型的键值对,而且可以动态添加或删除属性。
  • 许多其他语言中也有对象类型,但它们可能更接近于结构体或类实例,具有固定的成员列表。
  1. 函数作为一等公民
  • JavaScript 函数可以被赋值给变量、作为参数传递给其他函数以及作为函数返回值,这被称为“一等函数”或“第一类函数”。
  • 虽然一些现代语言也支持此特性(例如 Python 和 Scala),但在早期很多语言如 C 语言中函数并不具备这样的灵活性。
  1. 数组和数据结构
  • JavaScript 数组是动态大小的,并且可以包含不同类型的元素,这是与许多静态类型语言(如 C 语言数组)的不同之处。
  • 另外,JavaScript 还提供了灵活的对象字面量和 Map、Set 等集合数据结构。
  1. 特殊的 nullundefined 类型
  • JavaScript 有 nullundefined 两种表示空值或未定义状态的类型,而许多其他语言可能只有一种方式来表达类似的概念。
  1. typeof 操作符的行为
  • JavaScript 的 typeof 操作符可以用来检测变量的类型,但它返回的结果有些特例,比如 typeof null 返回 "object",这是 JavaScript 中的一个历史遗留问题。
  1. 新增数据类型
  • 随着 ECMAScript 标准的演进,JavaScript 添加了新的数据类型,比如 ES6 中引入的 Symbol 类型,以及 ES2020 中的 BigInt 类型,这些在传统的 C 家族语言或其他一些较早的语言中是没有的。

小结

光有数据类型,很多事还不能做,很多知识都是这样,前后交错的,学习时通过示例掌握涉及到的内容,不限于本节主题。

相关文章
|
2天前
|
移动开发 HTML5
HTML5/CSS3粒子效果进度条代码
HTML5/CSS3进度条应用。这款进度条插件在播放进度过程中出现粒子效果,就像一些小颗粒从进度条上散落下来
15 0
HTML5/CSS3粒子效果进度条代码
|
6天前
|
移动开发 前端开发 JavaScript
:掌握移动端开发:HTML5 与 CSS3 的高效实践
:掌握移动端开发:HTML5 与 CSS3 的高效实践
22 1
|
10天前
|
JSON JavaScript 前端开发
使用JavaScript和XLSX.js将数据导出为Excel文件
使用JavaScript和XLSX.js将数据导出为Excel文件
21 0
|
11天前
|
移动开发 前端开发 JavaScript
【专栏:HTML与CSS实战项目篇】使用HTML5与CSS3制作一个动态表单验证页面
【4月更文挑战第30天】本文介绍了使用HTML5和CSS3创建动态表单验证页面的方法。首先,简述HTML5用于构建网页内容,CSS3用于描述样式。接着,分四步展示实现过程:1) 设计包含输入框和提示信息的表单结构;2) 使用CSS3创建样式,增强视觉效果;3) 使用JavaScript监听输入事件,动态验证表单并显示错误信息;4) 测试和调试确保跨平台兼容性。通过学习,开发者能掌握创建带验证功能的表单,提升用户体验。
|
12天前
|
JavaScript 前端开发 开发工具
【JavaScript 技术专栏】Node.js 基础与实战
【4月更文挑战第30天】本文介绍了Node.js的基础及应用,包括事件驱动的非阻塞I/O、单线程模型和模块系统。内容涵盖Node.js的安装配置、核心模块(如http、fs、path)及实战应用,如Web服务器、文件操作和实时通信。文章还讨论了Node.js的优劣势、与其他技术的结合,并通过案例分析展示项目实施流程。总结来说,Node.js是高效后端开发工具,适合构建高并发应用,其广阔的应用前景值得开发者探索。
|
12天前
|
JSON JavaScript 前端开发
深入探讨javascript的流程控制与分支结构,以及js的函数
深入探讨javascript的流程控制与分支结构,以及js的函数
|
18天前
|
JavaScript 前端开发 算法
< JavaScript小技巧:如何优雅的用【一行代码 】实现Js中的常用功能 >
在开发中,采用简洁的语法和结构,遵循一致的命名规范,具有良好的代码组织和注释,能很好的提高代码的质量。可读性:易于阅读和理解。清晰的命名、简洁的语法和良好的代码结构可以使代码的意图更加明确,降低理解代码的难度,提高代码的可读性。可维护性:易于维护。当代码逻辑清晰、结构简洁时,开发者可以更快速地定位和修复bug,进行功能扩展或修改。同时,可读性高的代码也有助于后续的代码重构和优化。可扩展性:更具有扩展性和灵活性。清晰的代码结构和简洁的代码风格使得添加新功能、修改现有功能或扩展代码更加容易。
< JavaScript小技巧:如何优雅的用【一行代码 】实现Js中的常用功能 >
|
19天前
|
JavaScript 前端开发
js开发:请解释this关键字在JavaScript中的用法。
【4月更文挑战第23天】JavaScript的this关键字根据执行环境指向不同对象:全局中指向全局对象(如window),普通函数中默认指向全局对象,作为方法调用时指向调用对象;构造函数中指向新实例,箭头函数继承所在上下文的this。可通过call、apply、bind方法显式改变this指向。
8 1
|
27天前
|
XML 编解码 前端开发
css设计文本样式 前端开发入门笔记(十二)
css设计文本样式 前端开发入门笔记(十二)
7 0
|
27天前
|
Web App开发 XML 前端开发
CSS中的非布局样式+CSS布局 前端开发入门笔记(十一)
CSS中的非布局样式+CSS布局 前端开发入门笔记(十一)
33 0