新闻中心

j*ascript变量有哪些类型_如何正确声明和使用它们?

2025-12-16
浏览次数:
返回列表
J*aScript变量无类型,值才有类型;七种原始类型(string、number、bigint、boolean、null、undefined、symbol)不可变且按值传递,其余均为object类型(可变、按引用传递);声明优先用const和let,避免var。

javascript变量有哪些类型_如何正确声明和使用它们?

J*aScript 变量本身没有“类型”,真正有类型的是(value),而变量只是指向这些值的“容器”或“标签”。理解这一点,是正确声明和使用变量的关键。

七种基本数据类型(原始类型)

它们是不可变的、按值传递的:

  • string:文本,如 "hello"'world'`template ${x}`
  • number:所有数字(整数、小数、NaN、Infinity),如 423.14NaN
  • bigint:大整数,用 n 结尾,如 123n(不能与 number 混算)
  • boolean:逻辑值,只有 truefalse
  • null:一个独立类型,表示“有意为空”的值(注意:typeof null === "object" 是历史 bug)
  • undefined:变量声明了但未赋值时的默认值,也用于对象中缺失的属性
  • symbol:唯一且不可变的标识符,常用于对象属性键,避免命名冲突,如 Symbol("id")

一种引用类型(对象类型)

除上述七种外,其余都是 object 类型(包括函数、数组、日期、正则、Map、Set、Promise 等)。它们是可变的、按引用传递(实际是“按共享拷贝”语义):

  • { name: "Alice" } —— 普通对象
  • [1, 2, 3] —— 数组(本质也是对象)
  • function() {}() => {} —— 函数(函数是“可调用对象”)
  • new Date()/\d+/new Map() 等 —— 内置对象实例

判断是否为对象,推荐用 Object.prototype.toString.call(x),比 typeof 更可靠。

晓象AI资讯阅读神器 晓象AI资讯阅读神器

晓象-AI时代的资讯阅读神器

晓象AI资讯阅读神器 72 查看详情 晓象AI资讯阅读神器

如何正确声明变量?优先用 const 和 let

避免使用 var(存在变量提升、函数作用域、易引发意外重声明等问题):

  • const:声明后不能重新赋值(但对象/数组内容仍可修改);适用于大多数场景,比如配置项、DOM 元素、函数、模块导入
  • let:可重新赋值,块级作用域;适用于需要修改的局部变量,如循环计数器、临时计算结果
  • var:仅在需兼容极老环境或明确需要函数作用域+提升行为时才考虑(极少)

示例:

const PI = 3.14159;           // ✅ 常量
const user = { name: "Tom" }; // ✅ 对象可声明为 const(不改引用即可)
user.age = 25;                // ✅ 允许修改属性

let count = 0;                // ✅ 需要递增时用 let
count++;                       

// ❌ 不要这样:
var x = 1;                    // 过时
x = "hello";                  // 类型随意切换虽可行,但降低可维护性

使用变量时的关键注意事项

  • 声明即初始化:避免 let x; 后长期不用,容易误用 undefined
  • 避免隐式全局:未声明直接赋值(如 foo = 123)会创建全局变量,严格模式下报错
  • 区分 =====:前者会强制类型转换,后者严格比较类型和值;日常开发一律用 ===
  • 检查 null/undefined 用 x == null(等价于 x === null || x === undefined),或更明确的 x === undefined / x === null
  • 解构赋值很实用:如 const { name, age } = user;,但注意源为 nullundefined 会报错,可加默认值或先校验

基本上就这些。记住:变量无类型,值才有;声明选 const 优先;用好作用域和严格相等,代码会更健壮、易读、少出错。

以上就是j*ascript变量有哪些类型_如何正确声明和使用它们?的详细内容,更多请关注其它相关文章!


# java  # 哪些网站推广过平安保险  # 的是  # 默认值  # 有哪些  # 报错  # 全局变量  # 才有  # 适用于  # 七种  # 如何正确  # 如何实现  # 作用域  # javascript  # 免费的信息推广网站平台  # 洛阳网站优化推广公司  # 推广全网营销包括什么  # 咸宁市网站建设步骤  # 中合网站建设  # 物流网站建设图片  # 网络营销的推广策略  # 烟台seo优化博客引流  # 江苏个人网站推广 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 在J*a中如何使用Exception包装底层异常_异常包装与信息传递方法说明  TikTok网页版直接登录 TikTok网页端官方平台入口  夸克浏览器网页版最新地址 夸克浏览器官方入口合集  火锅吃太多会怎样 火锅吃太多会上火吗  在Go语言中利用后缀数组处理多字符串:实现高效文本匹配与自动补全  Gmail邮箱申请注册直达_Gmail邮箱免费注册PC版官网入口2025  QQ邮箱在线登录平台 QQ邮箱个人邮箱网页版入口  如何创建没有密码的Windows本地账户_跳过微软账户登录的技巧【教程】  Spring Boot嵌入式服务器与J*a EE:功能支持深度解析  J*aScript中localStorage数据的获取、清洗与格式化教程  b站怎么取消点赞_b站点赞取消操作方法  PHP高效扁平化嵌套数组:使用array_merge与数组解包操作符  c++ 命名空间怎么用 c++ namespace使用指南  Go语言中的*string:深入理解字符串指针  12306几点到几点不能订票? | 官方最新系统维护时间全解析  Windows 11怎么彻底关闭定位_Windows 11服务中禁用Geolocation  KFC游戏互动怎么赢取优惠券_KFC线上游戏活动参与与优惠代码赢取教程  Go RPC HTTP服务正确实现与常见陷阱解析  Python大型XML文件高效流式解析教程  小红书网页版入口链接分享 小红书官网直接进  深入理解与实现最大堆的Heapify过程:常见错误与修正  AO3最新入口2025公告_AO3中文官网合集  lar*el怎么安全地存储和获取配置文件中的敏感信息_lar*el敏感信息安全存储方法  谷歌浏览器一键优化方案_谷歌浏览器直达主页极速不卡版  steam官方网页快速访问 steam账号注册全流程  如何将一个大型PHP应用拆分为多个Composer包_微服务与模块化架构的Composer实践  mysql密码锁定怎么解锁_mysql密码锁定解锁后修改密码步骤  构建轻量级网站内部消息系统:Formspree 集成指南  Golang如何实现微服务鉴权与权限控制_Golang微服务鉴权与权限管理实践  J*aScript类型检查_j*ascript代码规范  CSS布局中意外空白:解决padding-top导致的顶部间距问题  千牛数据看板网页版_千牛数据看板网页版访问方法  J*a递归快速排序中静态变量的状态管理与陷阱  Win11 USB传输速度慢怎么解决 Win11 USB驱动更新与设置  Excel如何用迷你图显趋势_Excel用迷你图显趋势【趋势小图】  mc.js免安装版 mc.js一键畅玩入口  Win11怎么开启省电模式_Win11电池节电模式自动开启  CSS布局:解决全屏元素100%尺寸与外边距导致的页面溢出问题  押井守高度称赞《辐射4》:玩了八年都停不下来!  期待已久:小米17 Ultra、小米首款NAS本月登场  Win11蓝牙耳机断连怎么解决 Win11蓝牙设置重新配对与驱动更新【技巧】  css滚动区域卡顿如何改善_css滚动问题用will-change优化渲染  LocoySpider如何部署到云服务器_LocoySpider云部署的远程配置  C++ vector二维数组定义_C++ vector of vector用法  Lar*el 8 多关键词数据库搜索优化实践  css子元素高度不一致导致布局错位怎么办_使用align-items:stretch解决高度差异  PS5 Pro有点优势但不多! 《燕云十六声》PS5平台与PC性能画面对比  Win11怎么查看显卡显存 Win11显示适配器属性及专用视频内存查询  漫蛙MANWA漫画主页官方入口 漫蛙漫画最新在线阅读地址  KFC早餐时段怎么领特惠代码_KFC早餐订餐优惠代码获取与使用说明 

搜索