繁体   English   中英

从节点脚本调用时如何跳过 Yeoman 生成器步骤

[英]How to skip Yeoman generator step when invoked from node script

我有一个节点 js 脚本,它调用我编写的 Yeoman 生成器,我想跳过提示步骤,因为我正在从脚本传递生成器的数据。 我搜索了文档,但没有找到与此相关的任何内容。 有可能吗?

我的脚本看起来像这样

const yeoman = require('yeoman-environment');
const env = yeoman.createEnv();

env.lookup(() => {

    env.run('mygenerator:subgenerator --moduleName Test3', {'skip-install': true, 'skip-prompting': true }, err => {
        console.log('done');
    });
});

我的发电机没有什么特别的:

const BaseGenerator = require('./../base/index.js');

module.exports = class extends BaseGenerator {

    constructor(args, opts) {
        super(args, opts);

        this.props = opts;

        const destinationFolder = args.destinationFolder || '';
        const moduleName = args.moduleName || '';

        this.props = {
            moduleName,
            destinationFolder,
        };
    }

    prompting() {
        //...
    }

    writing() {
        //...
    }

};

我知道生成器获取我从脚本传递的数据。 我可能有一个处理输入的生成器,另一个只用于编写文件。 但是最好只有一个代码并且能够跳过一些步骤。

我在一些 stackoverflow 答案中看到人们将 { 'skip-install': true } 选项传递给生成器。 然后我试图通过 {'skip-prompting': true },但它没有做任何事情。

谢谢!

编辑

我解决这个问题的方法如下:

我所有的子生成器都扩展了我编写的 BaseGenerator,它是从 Yeoman 扩展而来的。 在我的 BaseGenerator 中,我添加了这个方法:

    shouldPrompt() {
        return typeof this.props.options === 'undefined' || 
            (typeof this.props.options.moduleName === 'undefined' &&
             typeof this.props.options.destinationFolder === 'undefined');
    }

我在我的生成器中只使用了 2 个参数,moduleName 和 destinationFolder。 所以,这就是我想要检查的全部内容。 然后,在子生成器中我添加了这个:

    prompting() {

        if (this.shouldPrompt()) {

            this.log(chalk.red('Reducer generator'));

            const prompts = [ /*...*/ ];

            return this.prompt(prompts).then((props) => { this.props.options = props; });
        }

    }

您需要定义optionsarguments以从终端接受这些参数:http: //yeoman.io/authoring/user-interactions.html

然后,只需使用 JavaScript 运行或不运行this.prompt()调用(使用 if/else 结构或任何其他适用于您的用例的条件)

请记住,Yeoman 仍然只是 JS 代码 :)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM