编程笔记 html5cssjs 065 JavaScrip数据类型

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

  • 一、JavaScript 数据类型
  • 二、JavaScrip 数据类型分类:
  • 三、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),用于表示计算结果无法表示为数字时的结果
      
  2. String(字符串型):

    • 字符串是由零个或多个字符组成的有序序列,用单引号 ' 或双引号 " 包围。
    • 示例:
      let name = 'Aniu'; // 单引号定义字符串
      let greeting = "Hello, World!"; // 双引号定义字符串
      let multiLineStr = `This is a multi-line string`; // ES6 中的模板字面量(Template literal)
      
  3. Boolean(布尔型):

    • 表示逻辑值,仅有两个可能的取值:truefalse
    • 示例:
      let isStudent = true;
      let hasPassed = false;
      
  4. Undefined(未定义型):

    • 当变量声明但未初始化时,其值默认为 undefined
    • 示例:
      let age;
      console.log(age); // 输出: undefined
      
  5. Null(空对象型):

    • null 是一个特殊的值,表示“无”或者“空对象引用”,它与 undefined 类似但不完全相同,在某些情况下用于显式地表示空值或没有对象值的情况。
    • 示例:
      let obj = null; // 显示对象为空
      
  6. Symbol(符号型):

    • 自从 ECMAScript 6 (ES6) 引入以来,Symbol 是一种原始数据类型,每个 Symbol 值都是唯一的,不可变的,并且不能与其他类型的值进行比较。
    • 示例:
      let sym = Symbol("description"); // 创建一个symbol值
      
  7. BigInt(大整数型):

    • BigInt 是从 ECMAScript 2020 开始支持的数据类型,用于表示超过 Number 类型安全整数范围(-2^53 to 2^53 - 1)的大整数。
    • 示例:
      let largeNum = 123456789012345678901234567890n; // 后缀n表示BigInt类型
      
  8. 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# 等静态类型语言要求在编译阶段就需要明确变量的类型,并且在程序执行过程中不能改变。
  2. 弱类型

    • JavaScript 具有弱类型的特点,允许不同类型的数据之间进行隐式转换(如字符串和数字相加时,JavaScript 会尝试将字符串转换为数字)。
    • 强类型语言如 C 语言则不会自动进行这种类型的隐式转换,如果不同类型间操作未显式转换,编译器通常会报错。
  3. Object 类型特殊性

    • 在 JavaScript 中,对象是一种复杂数据类型,它可以容纳任何类型的键值对,而且可以动态添加或删除属性。
    • 许多其他语言中也有对象类型,但它们可能更接近于结构体或类实例,具有固定的成员列表。
  4. 函数作为一等公民

    • JavaScript 函数可以被赋值给变量、作为参数传递给其他函数以及作为函数返回值,这被称为“一等函数”或“第一类函数”。
    • 虽然一些现代语言也支持此特性(例如 Python 和 Scala),但在早期很多语言如 C 语言中函数并不具备这样的灵活性。
  5. 数组和数据结构

    • JavaScript 数组是动态大小的,并且可以包含不同类型的元素,这是与许多静态类型语言(如 C 语言数组)的不同之处。
    • 另外,JavaScript 还提供了灵活的对象字面量和 Map、Set 等集合数据结构。
  6. 特殊的 nullundefined 类型

    • JavaScript 有 nullundefined 两种表示空值或未定义状态的类型,而许多其他语言可能只有一种方式来表达类似的概念。
  7. typeof 操作符的行为

    • JavaScript 的 typeof 操作符可以用来检测变量的类型,但它返回的结果有些特例,比如 typeof null 返回 "object",这是 JavaScript 中的一个历史遗留问题。
  8. 新增数据类型

    • 随着 ECMAScript 标准的演进,JavaScript 添加了新的数据类型,比如 ES6 中引入的 Symbol 类型,以及 ES2020 中的 BigInt 类型,这些在传统的 C 家族语言或其他一些较早的语言中是没有的。

小结

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/655932.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

私域必看:让你事半功倍的多微信高效管理方法

随着私域运营的需求不断增长,对于使用微信进行运营的企业或个人,高效地管理微信变得越发重要。今天就分享一些高效管理多个微信账号的实用方法,帮你节省时间。 1.巧用标签和分组 微信的标签和分组功能,相信很多人都使用过&#xf…

c++入门语法—————引用,内联函数,auto关键字,基于范围的for循环,nullptr

文章目录 一.引用1.引例2.注意事项3.应用场景1.做参数(a:输出型参数b:内容较大参数)2.做返回值(a:修改返回值,b:减少拷贝) 4.引用和指针的区别 二.内联函数1.为什么有内联函数2.用法和底层3.特性 三.auto关键字1.基础示…

R语言(数据导入,清洗,可视化,特征工程,建模)

记录一下痛失的超级轻松的数据分析实习(线上),hr问我有没有相关经历,我说我会用jupyter book进行数据导入,清洗,可视化,特征工程,建模,python学和用的比较多,…

LeetCode 2808. 使循环数组所有元素相等的最少秒数,简单哈希

一、题目 1、题目描述 给你一个下标从 0 开始长度为 n 的数组 nums 。 每一秒,你可以对数组执行以下操作: 对于范围在 [0, n - 1] 内的每一个下标 i ,将 nums[i] 替换成 nums[i] ,nums[(i - 1 n) % n] 或者 nums[(i 1) % n] 三…

[计算机提升] 删除空间占用大的文件(夹)

5.3 删除空间占用大的文件(夹) 5.3.1 hiberfil.sys 说明: 该文件是系统休眠文件。 对策: 使用CMD命令:powercfg -h off关闭休眠,然后重启电脑后该文件则会自动删除。但是电脑以后没有了休眠功能。读者可以根据实际情况进行取舍。…

c++如何使用volatile关键字保证线程安全?explicit

volatile C中的volatile关键字是一种类型修饰符,用它声明的变量表示可以被某些编译器未知的因素更改,比如操作系统、硬件或者其他线程等。 使用volatile关键字可以防止编译器对该变量的访问进行优化,从而保证每次都从内存中读取或写入该变量…

element——loading加载效果

两种使用方式 1.直接在标签上使用 <div v-loading.fullscreen.lock"loading" element-loading-text"加载中......" element-loading-spinner"el-icon-loading " element-loading-background"#fff"> 指令 v-loading.fullscre…

Log4j Log4j2

前言 今天抽时间来把这个日志框架学学&#xff0c;毕竟经常用&#xff0c;虽然不用自己写&#xff0c;但是书到用时方恨少&#xff0c;技多不压身。而且最近我的 GUI 软件中有一个关于日志问题的希望学完能够感觉解决掉。 Log4j & Log4j2 Log4j2 是 Log4j 的升级版&#x…

从理论到实践,如何用TRIZ破解研发中的技术难题?

自科技飞速发展以来&#xff0c;技术问题层出不穷&#xff0c;成为许多企业和研究机构研发过程中难以突破的瓶颈。然而&#xff0c;有一个强大的工具&#xff0c;能帮助我们解决这些问题&#xff0c;那就是TRIZ。 一、TRIZ是什么 TRIZ&#xff0c;全称是"发明问题解决理…

【Java程序设计】【C00178】基于SSM的NBA球队管理系统(论文+PPT)

基于SSM的NBA球队管理系统&#xff08;论文PPT&#xff09; 项目简介项目获取开发环境项目技术运行截图 项目简介 这是一个基于ssm的NBA球队管理系统 本系统分为前台用户和后台管理员2个功能模块。 前台用户&#xff1a;当游客打开系统的网址后&#xff0c;首先看到的就是首页…

AMC系列可编程智能电测仪表功能以及选型

功能&#xff1a; AMC 系列可编程智能电测仪表是针对电力系统、工矿企业、公用设施、智能大厦的电力监控需求而设计的智能仪表&#xff0c;它集成电力参数的测量(如单相或者三相的电流、电压、有功功率、无功功率、视在功率、频率、功率因数)以及电能监测和考核管理。采用高亮…

20240130在ubuntu20.04.6下给GTX1080安装最新的驱动和CUDA

20240130在ubuntu20.04.6下给GTX1080安装最新的驱动和CUDA 2024/1/30 12:27 缘起&#xff0c;为了在ubuntu20.4.6下使用whisper&#xff0c;以前用的是GTX1080M&#xff0c;装了535的驱动。 现在在PDD拼多多上了入手了一张二手的GTX1080&#xff0c;需要将安装最新的545的驱动程…

精细化客户管理,这篇文章教会您!

如何做好客户精细化管理? 对于企业来说&#xff0c;不止要做到客户拉新&#xff0c;同时&#xff0c;也要做到让新客户变成老客户&#xff0c;让客户多次高频次购买。否则客户如果只是来购买一次&#xff0c;客户回购率低&#xff0c;长期以往&#xff0c;那企业的生存资本&a…

kubernetes-快速部署一套k8s集群

1、前置知识点 1.1 生产环境可部署Kubernetes集群的两种方式 目前生产部署Kubernetes集群主要有两种方式&#xff1a; kubeadm Kubeadm是一个K8s部署工具&#xff0c;提供kubeadm init和kubeadm join&#xff0c;用于快速部署Kubernetes集群。 二进制包 从github下载发行…

《CSS3》田字网格背景(外实线内虚线)的实现

一、前言 记录一些有趣的CSS实现方式&#xff0c;总所周知&#xff0c;当一段效果可以通过CSS实现的时候&#xff0c;绝不使用Javascript来实现&#xff0c;因此记录一些有意思的CSS效果&#xff0c;一来是方便自己学习&#xff0c;另一来是方便以后在需要使用到的时候能快速找…

ubuntu18.04更换软件源

一、步骤 1. 备份原软件源 sudo cp /etc/apt/sources.list /etc/apt/sources.list.backup2. 修改软件源(源从下面找) sudo gedit /etc/apt/sources.list3. 更新软件源 sudo apt update二、现有软件源 1.官方自带源 #deb cdrom:[Ubuntu 18.04.6 LTS _Bionic Beaver_ - Rel…

async 与 awite

async 和 await 是 JavaScript 中用于处理异步操作的关键字。 async 函数是一个返回 Promise 对象的函数&#xff0c;它在函数体内部使用 await 来等待 Promise 对象执行结果。使用 async 函数可以让代码更加简洁易懂&#xff0c;避免了回调函数嵌套的问题。 例如&#xff1…

基于YOLOv8深度学习的水稻叶片病害智能诊断系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战

《博主简介》 小伙伴们好&#xff0c;我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源&#xff0c;可关注公-仲-hao:【阿旭算法与机器学习】&#xff0c;共同学习交流~ &#x1f44d;感谢小伙伴们点赞、关注&#xff01; 《------往期经典推…

Vue3使用vant检索组件van-search的坑

当清空按钮与检索按钮同时居右时&#xff0c;点击clear清空按钮事件时会同时触发click-right-icon事件,如下配置&#xff1a; <van-searchv-model"form.search"show-actionshape"round"left-icon""right-icon"search"placeholder&…

Python(19)Excel表格操作Ⅰ

目录 导包 读取EXCEL文件 1、获取worksheet名称 2、设定当前工作表 3、输出目标单元格数据 4、工作表.rows&#xff08;行&#xff09; 5、工作表.columns&#xff08;列&#xff09; 小结 导包 要想使用 python 操作 Excel 文件&#xff0c;应当导入 openpyxl 包。在…