AdonisJS v7 已完成功能开发,正在进行最终验证。 了解更多

命令标志

命令标志

标志是用两个连字符 (--) 或单个连字符 (-)(称为标志别名)提到的命名参数。标志可以按任何顺序提及。

你必须将标志定义为类属性,并使用 @flags 装饰器对它们进行装饰。在下面的示例中,我们定义了 resourcesingular 标志,两者都表示布尔值。

import { BaseCommand, flags } from '@adonisjs/core/ace'
export default class MakeControllerCommand extends BaseCommands {
@flags.boolean()
declare resource: boolean
@flags.boolean()
declare singular: boolean
}

标志类型

Ace 允许定义以下类型之一的标志。

布尔标志

布尔标志使用 @flags.boolean 装饰器定义。提及该标志将其值设置为 true。否则,标志值为 undefined

make:controller --resource
# this.resource === true
make:controller
# this.resource === undefined
make:controller --no-resource
# this.resource === false

最后一个示例显示布尔标志可以使用 --no- 前缀进行否定。

默认情况下,否定的选项不显示在帮助输出中。但是,你可以使用 showNegatedVariantInHelp 选项启用它。

export default class MakeControllerCommand extends BaseCommands {
@flags.boolean({
showNegatedVariantInHelp: true,
})
declare resource: boolean
}

字符串标志

字符串标志在标志名称后接受一个值。你可以使用 @flags.string 方法定义字符串标志。

import { BaseCommand, flags } from '@adonisjs/core/ace'
export default class MakeControllerCommand extends BaseCommands {
@flags.string()
declare model: string
}
make:controller --model user
# this.model = 'user'

如果标志值包含空格或特殊字符,则必须将其包裹在引号 "" 内。

make:controller --model blog user
# this.model = 'blog'
make:controller --model "blog user"
# this.model = 'blog user'

如果提及了标志但未提供值(即使标志是可选的),则会显示错误。

make:controller
# Works! The optional flag is not mentioned
make:controller --model
# Error! Missing value

数字标志

数字标志的解析类似于字符串标志。但是,会对值进行验证以确保其为有效数字。

你可以使用 @flags.number 装饰器创建数字标志。

import { BaseCommand, flags } from '@adonisjs/core/ace'
export default class MakeUserCommand extends BaseCommands {
@flags.number()
declare score: number
}

数组标志

数组标志允许在运行命令时多次使用该标志。你可以使用 @flags.array 方法定义数组标志。

import { BaseCommand, flags } from '@adonisjs/core/ace'
export default class MakeUserCommand extends BaseCommands {
@flags.array()
declare groups: string[]
}
make:user --groups=admin --groups=moderators --groups=creators
# this.groups = ['admin', 'moderators', 'creators']

标志名称和描述

默认情况下,标志名称是类属性名称的短横线连接形式 (dashed case)。但是,你可以通过 flagName 选项定义自定义名称。

@flags.boolean({
flagName: 'server'
})
declare startServer: boolean

标志描述显示在帮助屏幕上。你可以使用 description 选项来定义它。

@flags.boolean({
flagName: 'server',
description: 'Starts the application server'
})
declare startServer: boolean

标志别名

别名是使用单个连字符 (-) 提到的标志的简写名称。别名必须是单个字符。

@flags.boolean({
alias: ['r']
})
declare resource: boolean
@flags.boolean({
alias: ['s']
})
declare singular: boolean

在运行命令时,可以组合标志别名。

make:controller -rs
# 等同于
make:controller --resource --singular

默认值

你可以使用 default 选项定义标志的默认值。当未提及标志或提及标志但没有值时,将使用默认值。

@flags.boolean({
default: true,
})
declare startServer: boolean
@flags.string({
default: 'sqlite',
})
declare connection: string

处理标志值

使用 parse 方法,你可以在标志值被定义为类属性之前对其进行处理。