当前位置: 首页 > news >正文

JavaScript基础知识合集笔记1——数据类型

文章目录

    • JavaScript中的数据类型
      • 基本数据类型
      • 引用类型
      • 存储区别

JavaScript中的数据类型

基本数据类型和复杂类型

基本数据类型

基础类型包含六种:Number、Bigint、String、Boolean、Undefined、null、symbol

  • Number(特殊值NaN,意为“不是数值”)
console.log(0/0); // NaN
console.log(-0/+0); // NaN
  • BigInt

BigInt 类型是最近被添加到 JavaScript 语言中的,用于表示任意长度的整数。

可以通过将 n 附加到整数字段的末尾来创建 BigInt 值。

// 尾部的 "n" 表示这是一个 BigInt 类型
const bigInt = 1234567890123456789012345678901234567890n;
  • String(字符串不可变!!!)
  • Boolean
    一些特殊的比较。
null == undefined //true
//通过Boolean可以将其他类型的数据转化成布尔值数据类型      				转换为 true 的值      			 转换为 false 的值String        				 非空字符串          				    "" Number 				非零数值(包括无穷值)					 0NaN Object 					 任意对象 							   null
Undefined 					N/A (不存在) 					     undefined
  • Undefined

当使用 var或 let声明了变量但没有初始化时,就相当于给变量赋予了 undefined值,和未定义不同哦!

let message;
console.log(message == undefined); // true
  • null
    typeof null 的结果为 “object”。这是官方承认的 typeof 的错误,这个问题来自于 JavaScript 语言的早期阶段,并为了兼容性而保留了下来。null 绝对不是一个 object。null 有自己的类型,它是一个特殊值。typeof 的行为在这里是错误的。
let car = null;
console.log(typeof car); // "object"
//请注意下面null并不是Object的实例
console.log(null instanceof Object);//false
  • symbol

符号的用途是确保对象属性使用唯一标识符,不会发生属性冲突的危险。

引用类型

复杂类型统称为Object

  • Object
    创建object常用方式为对象字面量表示法,属性名可以是字符串或数值
let person = {name: "Nicholas","age": 29,5: true
};
  • Array
    JavaScript数组是一组有序的数据,很特别的是,在js中,数组中每个槽位可以存储任意类型的数据。并且,数组也是动态大小的,会随着数据添加而自动增长。
let colors = ["red", 2, {age: 20 }]
colors.push(2)
  • Function
    函数实际上是对象,每个函数都是 Function类型的实例,而 Function也有属性和方法,跟其他引用类型一样
    函数的三种常见表达方式:函数声明、函数表达式、箭头函数
  1. 函数声明
function sum(a,b){return a+b;
}
  1. 函数表达式
let sum = function(a,b){return a+b;
}
  1. 箭头函数
let sum = (a,b)=>{return a+b;
}

除了上述说的三种之外,还包括Date、RegExp、Map、Set等

存储区别

  • 基本数据类型存储在栈中,栈中存放的是数值。
let a = 10;
let b = a; // 赋值操作
b = 20;
console.log(a); // 10值

a的值为一个基本类型,是存储在栈中,将a的值赋给b,虽然两个变量的值相等,但是两个变量保存了两个不同的内存地址。
在这里插入图片描述

  • 引用类型数据存放在堆中,每个堆内存对象都有对应的引用地址指向它,引用地址存放在栈中
var obj1 = {}
var obj2 = obj1;
obj2.name = "Xxx";
console.log(obj1.name); // xxx

obj1是一个引用类型,在赋值操作过程汇总,实际是将堆内存对象在栈内存的引用地址复制了一份给了obj2,实际上他们共同指向了同一个堆内存对象,所以更改obj2会对obj1产生影响。
在这里插入图片描述

相关文章:

  • Qt开发:QSettings的介绍和使用
  • 如何下载VSCode插件市场为VSIX文件
  • 2025第十六届蓝桥杯省赛第二场(京津冀)JAVA B组真题回顾
  • 数据库监控功能-oracle
  • 数据分析岗位-相关知识
  • Spring 学习笔记之 @Transactional 异常不回滚汇总
  • javase和java有什么区别
  • 7.学习笔记-Maven进阶(P75-P89)-进度(p75-P80)
  • Python----深度学习(基于DNN的PM2.5预测)
  • Win下Pycharm运行/调试配置脚本形参执行替换Linux下终端执行,进行调试需要注意的
  • Vue Composition API 与 Options API:全面对比与使用指南
  • 《人件》第三章 正确的人
  • 2025.04.26-美团春招笔试题-第四题
  • 升级 Spring Boot CLI
  • windows上的 Vmware Workstation 环境搭建
  • cloud项目同一个服务,执行不同业务需求,nacos进行分组
  • 6.Geometric Intersection (几何求交)- Preliminary
  • LLM基础之源码一
  • 开发首个Spring Boot应用
  • 车载诊断架构 --- 用于学习的诊断上位机工具
  • 财政部下达农业生产防灾救灾资金3.76亿元,支持黄淮海等地抗旱保春播
  • 上海市委常委会传达学习总书记重要讲话精神,研究张江科学城建设等事项
  • 马上评|演唱会云集,上海如何把“流量”变“留量”
  • 铁路上海站五一假期预计发送446万人次,同比增长8.4%
  • 著名统计学家、北京工业大学应用数理学院首任院长王松桂逝世
  • 甘肃张掖至重庆航线开通,串起西北与西南文旅“黄金走廊”