Angular 18+ 高级教程 – Naming Conversion
前言
命名规范对项目维护是很重要的. Angular 对项目的渗透很大的, 必须做好命名规范, 不然会很乱.
InjectionToken
InjectionToken = UPPER_SNAKE_CARE
const SERVICE_CONFIG = new InjectionToken('ServiceConfig');
variable name 用 UPPER_SNAKE_CARE
InjectionToken 的参数用 PascalCase 或者 UPPER_SNAKE_CARE



Attribute and Property
element attribute and property name = camelCase
angular.io example 有 camelCase 和 kebab-case,不过我看绝大部分都是用 camelCase 居多。
<bank-account bankName="RBC" account-id="4747"></bank-account>
Event
event handler method
如果没有一个具体的执行名字,请不要放 (click)="onClick()" 放 "handleClick()"。

ValidationErrors
ValidationErrors key 用 camelCase
from Angular Docs

不过 built-in 的 minLength 和 maxLength 的 key 是 lowercase 'minlength' 和 'maxlength' 哦,奇葩。

Directive Selector
Angular CDK Derective selector 用 kebab-case 还是 camelCase?

CdkScrollable 指令 kebab-case 和 camelCase 都能接受。

CdkVirtualScrollableElement 指令只能接受 camelCase

CdkHeaderCell 指令只能接受 kebab-case。
显然,它们没有统一规范。不过通常 element 是用 kebab-case,attribute 用 camelCase。遇到例外比如 (th[cdk-header-cell]) 也没办法,只能 follow 它。
组件 attribute selector
通常组件是 tag,指令通常是 attribute。
<my-component myDirective></my-component>
但这也只是通常。
许多情况下组件也可能是 attrbute,这种情况下要用 kebab-case 还是 camelCase 呢?

我觉得像 Angular Material Button 这样使用 kebab-case 挺好的。
当组件的 selector 是 attribute 时使用 kebab-case。
@HostBinding and @HostListener Decorator
官网的 guide 是叫我们尽量用 @HostBinding Decorator 对比在 @Directive host property

但是 Angular Material 一直没有 follow 这个 guide

如今 Angular 正在去 Decorator 化,所以我建议使用 @Directive host property。
Animation CSS Property
依据官网教程,使用 camelCase

我觉得 camelCase 比 kebab-case 好,因为 Web Animation API 是只能使用 camelCase,这样比较统一。
Animation Trigger Name
下面这些是从 Angular Material 源码中抄出来的 Trigger Name:
- detailExpand
- panelAnimation
- state
- transformPanel
- fadeInCalendar
- dialogContainer
- indicatorRotate
- bodyExpansion
- transitionMessages
- transformMenu
- fadeInItems
- transformPanelWrap
- transformPanel
- transform
- indicator
- leftPointer
- rightPointer
- arrowOpacity
- arrowPosition
- allowChildren
- horizontalStepTransition
- verticalStepTransition
- translateTab
没有统一规范,但大部分有 2 个特性
- 对象 - 比如 panel, Calendar, dialog, body, Messages, Menu, Items 等等 - 有时候在前面,有时候在后面 
- 动作 - 比如 Expand, transform, fadeIn, Rotate 等等 - 有时候在前面,有时候在后面,有时候只有对象没有动作。 
当然还有一些比较直接的:panelAnimation,state。
我个人的规范是:
- 如果这个 trigger 会被用在多个 element 上,那取个动作名字就好了。 
- 如果是用在指定 element 上,最好配个对象名字。 
- 如果动作不好取,就直接叫 panelAnimation 或者 panelAnimationState 就好了。 
x, y, top, right, bottom, left, vertical, horizontal
vertical 和 horizontal 的抽象叫 orientation (follow Angular Material)
x, y 抽象叫 axis (轴的意思,follow Angular Material)
top, right, bottom, left 抽象叫 position 或 direction (follow Angular Material)
exportAs
参考 Angular Material


指令和组件都可能会有 exportAs,
exportAs 用的是 camelCase,通常名字就和 element tag 或 attribute 一样。
String literal union types
参考 Angular Material 源码





各种 case styles 都有,但绝大多数是 lowercase single word。
通常这些 string literal 会被用在 property 和 class name。
property 是 camelCase,class name 是 kebab-case 所以用这 2 种 case styles 就挺安全的了。
如果遇到冲突,我们可以做一些 conversion。
像这样:

 
//#region combineToCamelCase
export function combineToCamelCase<T1 extends string, T2 extends string>(
v1: T1,
v2: T2,
): `${Uncapitalize<T1>}${Capitalize<T2>}`;
export function combineToCamelCase<T1 extends string, T2 extends string, T3 extends string>(
v1: T1,
v2: T2,
v3: T3,
): `${Uncapitalize<T1>}${Capitalize<T2>}${Capitalize<T3>}`;
export function combineToCamelCase<T1 extends string, T2 extends string, T3 extends string, T4 extends string>(
v1: T1,
v2: T2,
v3: T3,
v4: T4,
): `${Uncapitalize<T1>}${Capitalize<T2>}${Capitalize<T3>}${Capitalize<T4>}`;
export function combineToCamelCase(...values: string[]): string {
return values
.map((value, index) =>
index === 0
? value.substring(0, 1).toLowerCase() + value.substring(1)
: value.substring(0, 1).toUpperCase() + value.substring(1),
)
.join('');
}
//#endregion //#region combineToPascalCase
export function combineToPascalCase<T1 extends string, T2 extends string>(
v1: T1,
v2: T2,
): `${Capitalize<T1>}${Capitalize<T2>}`;
export function combineToPascalCase<T1 extends string, T2 extends string, T3 extends string>(
v1: T1,
v2: T2,
v3: T3,
): `${Capitalize<T1>}${Capitalize<T2>}${Capitalize<T3>}`;
export function combineToPascalCase<T1 extends string, T2 extends string, T3 extends string, T4 extends string>(
v1: T1,
v2: T2,
v3: T3,
v4: T4,
): `${Capitalize<T1>}${Capitalize<T2>}${Capitalize<T3>}${Capitalize<T4>}`;
export function combineToPascalCase(...values: string[]): string {
return values.map(value => value.substring(0, 1).toUpperCase() + value.substring(1)).join('');
}
//#endregion //#region combineToKebabCase
export function combineToKebabCase<T1 extends string, T2 extends string>(
v1: T1,
v2: T2,
): `${Lowercase<T1>}-${Lowercase<T2>}`;
export function combineToKebabCase<T1 extends string, T2 extends string, T3 extends string>(
v1: T1,
v2: T2,
v3: T3,
): `${Lowercase<T1>}-${Lowercase<T2>}-${Lowercase<T3>}`;
export function combineToKebabCase<T1 extends string, T2 extends string, T3 extends string, T4 extends string>(
v1: T1,
v2: T2,
v3: T3,
v4: T4,
): `${Lowercase<T1>}-${Lowercase<T2>}-${Lowercase<T3>}-${Lowercase<T4>}`;
export function combineToKebabCase(...values: string[]): string {
return values.map(value => value.toLowerCase()).join('-');
}
//#endregion
Change or Changes?
Angular Material 在写 @Output 时是用 xxxChange

但 xxxChanges 也有很多地方会使用哦





Angular 18+ 高级教程 – Naming Conversion的更多相关文章
- Siki_Unity_2-9_C#高级教程(未完)
		Unity 2-9 C#高级教程 任务1:字符串和正则表达式任务1-1&1-2:字符串类string System.String类(string为别名) 注:string创建的字符串是不可变的 ... 
- Pandas之:Pandas高级教程以铁达尼号真实数据为例
		Pandas之:Pandas高级教程以铁达尼号真实数据为例 目录 简介 读写文件 DF的选择 选择列数据 选择行数据 同时选择行和列 使用plots作图 使用现有的列创建新的列 进行统计 DF重组 简 ... 
- ios cocopods 安装使用及高级教程
		CocoaPods简介 每种语言发展到一个阶段,就会出现相应的依赖管理工具,例如Java语言的Maven,nodejs的npm.随着iOS开发者的增多,业界也出现了为iOS程序提供依赖管理的工具,它的 ... 
- 【读书笔记】.Net并行编程高级教程(二)-- 任务并行
		前面一篇提到例子都是数据并行,但这并不是并行化的唯一形式,在.Net4之前,必须要创建多个线程或者线程池来利用多核技术.现在只需要使用新的Task实例就可以通过更简单的代码解决命令式任务并行问题. 1 ... 
- 【读书笔记】.Net并行编程高级教程--Parallel
		一直觉得自己对并发了解不够深入,特别是看了<代码整洁之道>觉得自己有必要好好学学并发编程,因为性能也是衡量代码整洁的一大标准.而且在<失控>这本书中也多次提到并发,不管是计算机 ... 
- 分享25个新鲜出炉的 Photoshop 高级教程
		网络上众多优秀的 Photoshop 实例教程是提高 Photoshop 技能的最佳学习途径.今天,我向大家分享25个新鲜出炉的 Photoshop 高级教程,提高你的设计技巧,制作时尚的图片效果.这 ... 
- 展讯NAND Flash高级教程【转】
		转自:http://wenku.baidu.com/view/d236e6727fd5360cba1adb9e.html 展讯NAND Flash高级教程 
- Net并行编程高级教程--Parallel
		Net并行编程高级教程--Parallel 一直觉得自己对并发了解不够深入,特别是看了<代码整洁之道>觉得自己有必要好好学学并发编程,因为性能也是衡量代码整洁的一大标准.而且在<失控 ... 
- [转帖]tar高级教程:增量备份、定时备份、网络备份
		tar高级教程:增量备份.定时备份.网络备份 作者: lesca 分类: Tutorials, Ubuntu 发布时间: 2012-03-01 11:42 ė浏览 27,065 次 61条评论 一.概 ... 
- Angular CLI 使用教程指南参考
		Angular CLI 使用教程指南参考 Angular CLI 现在虽然可以正常使用但仍然处于测试阶段. Angular CLI 依赖 Node 4 和 NPM 3 或更高版本. 安装 要安装Ang ... 
随机推荐
- Kolla-ansible部署openStack
			目录 Kolla-ansible部署openStack 1. 简介 2. 环境准备 3. 部署 3.1 基础环境配置 3.1.1 配置主机名,所有节点操作,这里以openstack01为例 3.1.2 ... 
- php.ini文件与php.d
			`php.ini` 是 PHP 的主要配置文件,用于全局配置 PHP 的行为和功能.它包含了许多 PHP 的核心设置,如内存限制.错误报告级别.扩展加载等. `php.ini` 文件通常位于 PHP ... 
- [oeasy]python0036_牛说_cowsay_小动物说话_asciiart_figlet_lolcat_管道(祝大家新年快乐~)
			 牛说(cowsay) 回忆上次内容 上次我们研究了shell脚本的编程 并且在shell中实现了 循环语句 延迟命令 清屏命令 python命令 figlet命令  编辑 还能整点什么呢? 还想 ... 
- oeasy教您玩转vim - 81 - # 宏macro的进阶
			 宏的进阶 macro 回忆 关于宏,上次有4个要点 qa 开始录制宏 q 结束录制宏 @a 应用宏 qA 追加录制宏 甚至可以编辑宏 "ap 把宏作为文本粘贴出来 编辑之后 " ... 
- 字符—字符与整数的关系&&常用的库函数_C
			// Code file created by C Code Develop #include "ccd.h" #include "stdio.h" #incl ... 
- 基于vue.js 移动可视化,拖拽生成H5系统
			效果预览 功能简介 基于Vue.js(2.0)版本开发的,通过拖拽可视化的操作,生成H5的页面,类似易企秀的工具,前端展示页面运用了之前发布的 vue-animate-fullpage 插件进行动画渲 ... 
- 基于.NET开源、强大易用的短链生成及监控系统
			前言 今天大姚给大家分享一个基于.NET开源(MIT License).免费.强大易用的短链生成及监控系统:SuperShortLink. 项目介绍 SuperShortLink是一个基于.NET开源 ... 
- 小技巧:初始化后查看容器内某一bean的信息
			1.debug 2. 3.与容器名对应,可以看到容器的对应信息 4.输入表达式可以直接获取对应结果信息,这里查看的是默认SpringSecurity过滤链的bean 
- 【ActiveJdbc】05
			一.事务 通常在 Java ORM 中有一个显式连接或管理器对象(JPA 中的 EntityManager,Hibernate 中的 SessionManager 等). ActiveJDBC 中没有 ... 
- 跨平台字幕制作软件ARCTIME
			官网:http://arctime.cn/ 
