ng g 业务页

写在前面

ng generate(简写:ng g)用于生成业务组件页,默认 Angular 所提供的模板跟 ng-alain 所需要的会有一些不同,例如我们希望生成一个模块时应该包括导入 SharedModule

ng-alain 在此基础上增加了很多很酷的骚操作。

命令格式

  1. ng g ng-alain:[command name] [name] [options]

ng-alain 有自己的一套文件组织结构,当你破坏这些结构时,可能会导致下列指令产生异常。

Module 模块

生成一个 trade 模块:

  1. ng g ng-alain:module trade

会在 routes/trade 生成两个文件 trade.module.tstrade-routing.module.ts,你无法指定不生成 *-routing.module.ts 因为这是 ng-alain 的任性。

模块内容包括了导入 SharedModule 以及一些统一性导入与导出的方式,并且你不可能破坏这些变量名(例如:COMPONENTSCOMPONENTS_NOROUNTroutes)。

业务页

目前包含的业务组件页,包括:

  • empty 空白页

  • list 列表页

  • edit 编辑页

  • view 查看页

  • curd 列表、编辑、查看

trade 下生成 list 列表页:

  1. ng g ng-alain:list list -m=trade

注意: -m 是必须指定的,因为 ng-alain 认为页面应该在某个具体的模块里,而不是幽灵。

骚操作

一般而言,一个模块可能会包含相同类型的业务页,而我们产生的文件结构可能希望是:

  1. sys
  2. log
  3. view
  4. view.component.ts
  5. log.component.ts
  6. sys.module.ts

因此,当你希望生成的查看应该是在 log 组件(支持 log/list 多级写法)下面时,你可以这样子:

  1. ng g ng-alain:view view -m=sys -t=log

覆盖默认模板页

listeditviewempty 四个指令所产生默认页并非所在业务期望,可以覆盖它们。

例如覆盖 list 命令默认模板,在根目录 _cli-tpl 下创建目录名 _list,目录结构务必等同 原始list目录 的结构。

edit & view 页

对于 editview 默认是以模态框展示来生成,你可以改用页面展示则:

  1. ng g ng-alain:edit [page name] --modal=false

如果你不小心将收到【No provider for NzModalRef! 】表明你把一个需要使用 nzModalService 打开的模态框组件,用了路由注册的方式。打开模态框组件无须注册路由。

自定义页

除上述默认业务页以外,也可以自定义属于项目级别业务页,例如我们创建一个自己的编辑页模板,则只需要在项目的根目录创建以下目录结构:

  1. └── _cli-tpl
  2. └── edit // 模板名称
  3. └── __path__ // (名称固定值)
  4. └── __name@dasherize@if-flat__ // (名称固定值)
  5. ├── __name@dasherize__.component.ts // 组件类文件(名称固定值)
  6. ├── __name@dasherize__.component.html // 组件模板文件(名称固定值)
  7. └── __name@dasherize__.component.spec.ts // 组件测试文件(名称固定值)
  8. └── src

之后,只需要运行:

  1. ng g ng-alain:tpl [your template name] [name] -m=trade

自定义页参数同业务页一致。

如何编写模板文件

在自定义页的目录结构里我们看到文件名以 __ 前缀开头,事实上他们是一些变量占位符,Cli 默认传递一些参数及方法:

类型参数名默认描述
变量project-项目名
变量name-名称,相当于命令行的 <name>
变量path-目标路径
变量flatfalse文件是否扁平结构
变量inlineTemplatefalse是否内联模板(固定值:false
变量selector-组件 selector
变量componentName-组件名称
变量changeDetectionDefault组件 changeDetection
变量modal-是否使用 Modal 展示
方法decamelize-将字母串转换为由下划线分隔的所有小写字母
方法dasherize-将空格或下划线用破折号替换
方法camelize-返回字符串的小骆驼拼写法形式
方法classify-返回字符串的大骆驼拼写法形式
方法underscore-将字母串转换为由下划线分隔的所有小写字母
方法capitalize-返回字符串首字母大写

这些变量或方法可以在模板中使用,例如:<%=componentName%> 表示组件名,任何使用 <% %> 内可以使用 JavaScript 代码。有关模板编写可以参考:

自定义数据

tpl 命令在生成文件之前允许你进一步处理数据,命令在执行过程中会检查是否存在 _cli-tpl/_fix.js 文件,并调用 fix 方法,方法必须返回一个 Promise 对象,例如:

注: CLI 是一个 Node JS 程序,因此语法以 Node JS 为准。

  1. function fix(options) {
  2. return new Promise((resolve) => {
  3. resolve();
  4. });
  5. }
  6. module.exports = {
  7. fix
  8. };

fix 只有一个 options 参数,它包含 CLI 产生所有参数数据,哪怕是一些未定义参数,例如:

  1. ng g ng-alain:tpl list -m=setting --import-type=UserDto

其中 import-type 并不是命令自身的定义参数,但 options 会将这些未定义参数转换成 extraArgs 对象,因此你接收到的 options 会是:

  1. {
  2. "tplName": "test",
  3. "modal": true,
  4. ...
  5. "extraArgs": {
  6. "import-type": "UserDto"
  7. }
  8. }

options 对象会传递给模板引擎,由此你可以附加一些处理后的数据给 options,并在模板文件内使用它们,例如:

  1. {
  2. "tplName": "test",
  3. "modal": true,
  4. ...
  5. "extraArgs": {
  6. "import-type": "UserDto",
  7. "newData": "asdf"
  8. }
  9. }

你可以将 newData 应用到模板当中,例如 __name@dasherize__.component.html

  1. <page-header></page-header>
  2. <%= extraArgs.newData %>

结果为:

  1. <page-header></page-header>
  2. asdf