Jos*_*son 10 yeoman yeoman-generator
我正在组建一个Yeoman Generator并且无法理解composeWith()的options参数如何工作.我的目标是将用户输入从主生成器的提示传递给子生成器,我认为选项是这样做的方式.
我的主要生成器的提示看起来像这样:
prompting: function () {
var done = this.async();
var prompts = [
{
type : 'input',
name : 'name',
message : 'What is the name of your project?',
default : this.appname // Default to current folder name
}
];
this.prompt(prompts, function (answers) {
this.composeWith('app:subgenerator', {
options: {
name: answers.name;
}
},
{
local: require.resolve('generator-angular/app')
});
done();
}.bind(this)
)
}
Run Code Online (Sandbox Code Playgroud)
我已经尝试在我的子生成器中使用构造函数中的参数设置局部变量(因为我假设这是选项所在的位置),如下所示:
module.exports = generators.Base.extend({
constructor: function () {
generators.Base.apply(this, arguments);
this.foo = arguments.options.name;
}
}
Run Code Online (Sandbox Code Playgroud)
但这没效果.我试过控制台记录参数变量,它显示选项是一个对象,但它似乎是空的.
这是我如何通过生成器将用户输入传递给另一个,还是有另一种方法可以做到这一点?
您的子生成器需要像编写正常期望的选项一样编写.
module.exports = generators.Base.extend({
constructor: function () {
generators.Base.apply(this, arguments);
this.option('name');
},
initializing: function () {
console.log(this.options.name)
}
}
Run Code Online (Sandbox Code Playgroud)
有关详细信息,请参阅用户交互文档.
| 归档时间: |
|
| 查看次数: |
2331 次 |
| 最近记录: |