在提示之间传递数据



我可以在Yeoman的两个提示之间传递数据吗?

例如,我有两个提示,例如

{
  type: 'input',
  name: 'Name',
  message: 'Name?'
},{
  type: 'input',
  name: 'package',
  message: 'Package?',
  default: 'org.my.app.'+<prompt.name>
}

我想显示name属性作为包的默认值?我能想到的一种方法是:

  • 默认显示模板(如示例所示(
  • 稍后在为用户创建最终模板时更改该值。

我尝试的另一种方法是使用when

{
  type: 'input',
  name: 'Name',
  message: 'Name?'
},{
  when: (response) => {
    this.testValue = response.Name
    return true
  },
  type: 'input',
  name: 'package',
  message: 'Package?',
  default: 'org.my.app.'+this.testValue
}

但它提供了undefined,即使函数内部的值已存储在 this.testValue

有没有更好的方法?

我终于找到了答案。实现它的方法是使用两个提示变量,并在第一个 promise 返回后运行第二个

const prompt1 = [{
  type: 'input',
  name: 'Name',
  message: 'Name?'
}];
return this.prompt(prompt1).then(props => {
  const prompt2 = [{
    type: 'input',
    name: 'package',
    message: 'Package?',
    default: 'org.my.app.'+props.name
  }];
  return this.prompt(prompt2).then(props => {
   //code goes here
  });
});

最新更新