这些命名法可视为命名惯例,并无绝对与强制,为的是增加可识别性和可读性。一旦选用或设置好命名规则,在程序编写时应保持格式的一致性。
1. 驼峰命名法(Camel Case):
- 小驼峰命名法(Lower Camel Case):第一个单词的首字母小写;第二个单词开始每个单词的的首字母大写。例如:firstName、lastName。
- 大驼峰命名法(Upper Camel Case:每一个单词的首字母都大写。例如:FirstName、LastName、CamelCase。也被称为 Pascal 命名法(Pascal Case),源自于 Pascal 语言的命名惯例。
2. Snake Case:这是书写复合词或短语的一种惯例(practice)。复合词或短语中的各个单词之间用下划线(_)分隔并且没有空格。复合词中的每一个单词的首字母通常都是小写的,并且复合词的第一个字母既可以是大写的又可以是小写的,例如:“foo_bar”和“Hello_world”。一般认为 Snake Case 的可读性要比 Camel Case 要强。
3. 匈牙利命名法(貌似没什么卵用,不用看了):首次在BCPL语言中被大量使用。由于BCPL只有机器字这一种数据类型,因此++这种语言本身无法帮助程序员来记住变量的类型。匈牙利命名法通过明确每个变量的数据类型来解决这个问题++。
系统命名法与应用命名法的区别在于前缀的目的。
- 系统型匈牙利命名法(System Hungarian):前缀代表了变量的实际数据类型。
- lAccountNum:变量是一个长整数("l");
- arru8NumberList:变量是一个无符号8位整型数组("arru8");
- szName:变量是一个零结束字符串("sz"),这是西蒙尼最开始建议的前缀之一。
- 应用型匈牙利命名法(Apps Hungarian):前缀给出了变量目的的提示,或者说它代表了什么。
- rwPosition:变量代表一个行("rw")。
- usName:变量代表一个非安全字符串("us"),需要在使用前处理。
- strName:变量代表一个包含名字的字符串("str")但是没有指明这个字符串是如何实现的。
4. Studly caps:这是驼峰命名法的变种。相关资料比较少,wiki上的介绍。
Messages may be hidden in the capital and lower-case letters such as "ShoEboX" which spells "SEX" in capitals and "hobo" in lower-case. The webmail service Hotmail was originally stylized as HoTMaiL, which spells HTML in upper-case.
5. 额。。。用“-”作为分隔符的命名法叫什么?没找到相关的资料~但在 vuejs 的文档中看到这个术语:短横分隔命名kebab-case