2

我正在尝试使用 gulp-replace 任务将构建版本插入到我的 Angular 2 组件文件中。我正在从流程变量中检索构建版本process.env.npm_package_version。这部分工作正常,因为我能够将值记录到控制台并获得预期值。但是,我的任务的 gulp-replace 部分不起作用。我replace先执行任务。

任务:

const replace = require('gulp-replace');

gulp.task('replace', () => {
    let version = `${process.env.npm_package_version}`;
    gulp.src('src/app/app.component.ts')
        .pipe(replace('buildVersion', version))
        .pipe(gulp.dest('./'));
});

来源:

import { Component, OnInit } from '@angular/core';

@Component({
    selector: 'my-app',
    templateUrl: './app/app.component.html',
    styleUrls: ['./app/app.component.css']
})
export class AppComponent implements OnInit {
    constructor() {}
    ngOnInit() {}
    app = { version: "buildVersion", currentYear: new Date().getFullYear() };
}
4

1 回答 1

1

gulp dest是错的。很高兴它已修复。

顺便说一句,如果您的意图是:

1 - 复制到您的构建文件夹

一切都好,工作完成,但如果你的意图是:

2 - 覆盖原始

那么您的逻辑将无法在第二轮运行,因为您将替换字符串“buildVersion”,在这种情况下,您可能需要替换正则表达式,例如 /\d\d.\d\d.\d\d/

然后原始文件中的 buildVersion 可以是:

00.00.00

然后当它被替换为:

01.01.44

正则表达式仍将在第二轮工作。

我提到它的原因是因为您提到目标与源相关,这表明对我来说是覆盖。

于 2017-03-04T04:06:05.807 回答