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

javaScript变量命名规则

一、硬性规则(必须遵守,否则会报错)

这些是 JavaScript 语法强制要求的规则,违反会导致程序无法运行。

  1. 可以包含的字符

    • 字母(a-z, A-Z)
    • 数字(0-9)
    • 下划线(_
    • 美元符号($
  2. 首字符规则

    • 不能以数字开头。变量名的第一个字符必须是字母、下划线(_)或美元符号($)。
    let name;    // ✅ 正确
    let _private; // ✅ 正确
    let $element; // ✅ 正确
    let 2fast;    // ❌ 错误:不能以数字开头
    
  3. 区分大小写

    • myVariablemyvariable 是两个完全不同的变量。
    let caseMatters;
    let casematters; // 这是另一个变量
    
  4. 不能使用保留字/关键字

    • 不能使用 JavaScript 语言本身用于特殊目的的单词,如 let, if, for, function, return 等。
    let let;     // ❌ 错误:'let' 是关键字
    let class;   // ❌ 错误:'class' 是关键字
    let if;      // ❌ 错误:'if' 是关键字
    
  5. 不允许空格和连字符

    • 变量名中不能有空格或连字符(-)。
    let my variable; // ❌ 错误:包含空格
    let my-variable; // ❌ 错误:包含连字符(会被误认为是减法操作)
    

二、软性规则(最佳实践,建议遵守)

这些规则不会导致错误,但遵守它们可以使你的代码更专业、更易读、更易维护,是程序员之间的一种约定。

  1. 使用驼峰命名法

    • 这是 JavaScript 中最常见的命名约定。
    • 小驼峰命名法:第一个单词首字母小写,后续每个单词的首字母大写。用于变量名函数名
      let firstName;
      let totalAmount;
      function calculateTotalPrice() {}
      
    • 大驼峰命名法/帕斯卡命名法:每个单词的首字母都大写。用于类名构造函数
      class UserAccount {}
      function Car(model) { // 构造函数this.model = model;
      }
      
  2. 使用有意义的、描述性的名称

    • 变量名应该清楚地表明其用途或包含的数据,避免使用像 a, x, temp 这样模糊的名称(除非在非常短的循环中)。
    • ** Bad **:
      let d; // 做什么的?天数?日期?距离?
      let val;
      
    • ** Good **:
      let elapsedTimeInDays;
      let currentUser;
      let isModalOpen;
      
  3. 布尔变量通常以 is, has, can, should 开头

    • 这明确表示该变量是一个布尔值(true/false)。
    let isLoggedIn;
    let hasPermission;
    let canEdit;
    let shouldUpdate;
    
  4. 常量通常全大写,单词间用下划线分隔

    • 对于在程序运行过程中值永远不会改变的变量(用 const 声明),这是一种常见的约定。
    const MAX_USERS = 100;
    const API_BASE_URL = 'https://api.example.com';
    const PI = 3.14159;
    
  5. 避免使用短横线-

    • 虽然技术上不行,但也要提醒一下,JavaScript 变量名不支持短横线,它只用于 HTML 的属性(如 data-*)和 CSS 的类名。

三、合法与非法变量名示例

变量名是否合法原因
userName符合所有规则,且是良好的实践
_privateVar下划线开头常用于表示“私有”成员(但并非真正私有)
$jQueryObject$ 开头常用于表示 jQuery 或其他库包裹的对象
CONSTANT_VALUE全大写常量,良好实践
let是 JavaScript 的关键字
2ndPlace以数字开头
my-variable包含连字符
my variable包含空格
some@email包含非法字符 @

总结

规则类型要求示例
硬性规则字母、数字、_$组成,不能数字开头,不能是关键字myVar1, _temp, $item
软性规则(最佳实践)使用小驼峰命名法,名称要有意义,布尔值用 is/has 前缀,常量全大写firstName, isActive, MAX_SIZE

记住:清晰的变量名是代码文档的一种形式,它能极大地提高代码的可读性,让你和你的队友在未来更容易理解和维护代码。

http://www.xdnf.cn/news/1425313.html

相关文章:

  • MySQL基础知识保姆级教程(四)视图与约束
  • Chrome 如何清除浏览器缓存
  • 【开题答辩全过程】以 基于SpringBoot的校园一卡通管理系统的设计与实现为例,包含答辩的问题和答案
  • ESP32驱动数字麦克风INMP441
  • A2A + MCP 的python实现的最小可运行骨架
  • Jmeter实现参数化的4种方式
  • 构建AI智能体:二十、妙笔生花:Gradio集成DashScope Qwen-Image模型实现文生图
  • 人脸识别备案的重要意义
  • ES6新特性:JavaScript的进化装备箱[特殊字符]
  • 记一次使用函数式接口
  • A股大盘数据-20250901 分析
  • GD32入门到实战25--独立看门狗
  • JAVA后端开发——MyBatis 结合 MySQL JSON 类型查询详解
  • 【STM32】贪吃蛇 [阶段 3] 增强模块结构(架构优化)
  • curl 介绍及使用教程
  • python爬虫之selenium库进阶(小白五分钟从入门到精通)
  • 基本渗透概念
  • Raft 协议在 Nacos 中的实现
  • 从零开始实现Shell | Linux进程调度实战
  • Product Hunt 每日热榜 | 2025-09-01
  • 基于YOLOv11的脑卒中目标检测及其完整数据集——推动智能医疗发展的新机遇!
  • 齿轮里的 “双胞胎”:分度圆与节圆
  • [React]监听Form中某个字段的变化
  • 微算法科技(NASDAQ:MLGO)张量网络与机器学习融合,MPS分类器助力顶夸克信号识别
  • deepseek doubao chatgpt 优缺点分析
  • 并发--并发中的线程状态及不同状态下线程所在队列
  • React学习教程,从入门到精通, React 入门指南:创建 React 应用程序的语法知识点(7)
  • OpenCV-CUDA 图像处理
  • 数据库常见故障类型
  • 知识产品和标准化