gulp 打字稿抛出错误 TS2300:重复标识符 'moment'
gulp typescript throws error TS2300: Duplicate identifier 'moment'
我有一个使用 Yeoman gulp 打字稿生成器生成的 Angular 应用程序。
在构建打字稿期间突然没有任何明显原因(项目更改)开始抛出错误:
.tmp/typings/moment/moment-node.d.ts(6,16): error TS2300: Duplicate identifier 'moment'.
[22:08:34] [TypeScript] TypeScript error: .tmp/typings/moment/moment-node.d.ts(6,16): error TS2300: Duplicate identifier 'moment'.
.tmp/typings/moment/moment.d.ts(8,13): error TS2300: Duplicate identifier 'moment'.
请参阅以下文件的以下内容以供参考。
我从 gulp script
任务中删除了 'tsd:install' 以防止构建覆盖 d.ts 文件和 tsd.d.ts 文件。然后尝试修改 tsd.d.ts 来解决问题(我尝试删除 moment-node,moment,更改顺序,我也尝试编辑 moment.d.ts 和 moment-node.d.ts , 没有任何效果:/).
我的 tsd.json 文件:
{
"version": "v4",
"repo": "borisyankov/DefinitelyTyped",
"ref": "master",
"path": ".tmp/typings",
"bundle": ".tmp/typings/tsd.d.ts"
}
我的script.js(gulp 任务):
'use strict';
var path = require('path');
var gulp = require('gulp');
var conf = require('./conf');
var browserSync = require('browser-sync');
var $ = require('gulp-load-plugins')();
var tsProject = $.typescript.createProject({
target: 'es5',
sortOutput: true
});
gulp.task('scripts', ['tsd:install'], function () {
return gulp.src(path.join(conf.paths.src, '/app/**/*.ts'))
.pipe($.sourcemaps.init())
.pipe($.tslint())
.pipe($.tslint.report('prose', { emitError: false }))
.pipe($.typescript(tsProject)).on('error', conf.errorHandler('TypeScript'))
.pipe($.concat('index.module.js'))
.pipe($.sourcemaps.write())
.pipe(gulp.dest(path.join(conf.paths.tmp, '/serve/app')))
.pipe(browserSync.reload({ stream: true }))
.pipe($.size())
});
生成 tsd。d.ts:
/// <reference path="angular-local-storage/angular-local-storage.d.ts" />
/// <reference path="angular-ui-router/angular-ui-router.d.ts" />
/// <reference path="angularjs/angular-animate.d.ts" />
/// <reference path="angularjs/angular-cookies.d.ts" />
/// <reference path="angularjs/angular-mocks.d.ts" />
/// <reference path="angularjs/angular-resource.d.ts" />
/// <reference path="angularjs/angular-sanitize.d.ts" />
/// <reference path="angularjs/angular.d.ts" />
/// <reference path="bootstrap/bootstrap.d.ts" />
/// <reference path="d3/d3.d.ts" />
/// <reference path="jquery/jquery.d.ts" />
/// <reference path="moment/moment.d.ts" />
/// <reference path="moment/moment-node.d.ts" />
/// <reference path="toastr/toastr.d.ts" />
如果您指向 1.4.1 之类的特定版本而不是 "master" 作为参考:- 我认为它会为您修复。它对我有用。
{
"version": "v4",
"repo": "borisyankov/DefinitelyTyped",
"ref": "1.4.1",
"path": ".tmp/typings",
"bundle": ".tmp/typings/tsd.d.ts"
}
错误消息具有误导性。我相信这个原始错误的真正原因是由于类型定义文件暂时使用了您当前版本不支持的 TypeScript 功能。 运行 获取最新版本的 gulp-typescript 然后我认为一切都会为你工作,而不必将你的 TSD 文件限制为特定的修订版。将其限制为特定版本会有其自身的问题。
npm install gulp-typescript@2.9.2 --save-dev
删除 kendo all.d.ts 然后在 wwwroot 中重建您的网站。这对我有用
我有一个使用 Yeoman gulp 打字稿生成器生成的 Angular 应用程序。
在构建打字稿期间突然没有任何明显原因(项目更改)开始抛出错误:
.tmp/typings/moment/moment-node.d.ts(6,16): error TS2300: Duplicate identifier 'moment'.
[22:08:34] [TypeScript] TypeScript error: .tmp/typings/moment/moment-node.d.ts(6,16): error TS2300: Duplicate identifier 'moment'.
.tmp/typings/moment/moment.d.ts(8,13): error TS2300: Duplicate identifier 'moment'.
请参阅以下文件的以下内容以供参考。
我从 gulp script
任务中删除了 'tsd:install' 以防止构建覆盖 d.ts 文件和 tsd.d.ts 文件。然后尝试修改 tsd.d.ts 来解决问题(我尝试删除 moment-node,moment,更改顺序,我也尝试编辑 moment.d.ts 和 moment-node.d.ts , 没有任何效果:/).
我的 tsd.json 文件:
{
"version": "v4",
"repo": "borisyankov/DefinitelyTyped",
"ref": "master",
"path": ".tmp/typings",
"bundle": ".tmp/typings/tsd.d.ts"
}
我的script.js(gulp 任务):
'use strict';
var path = require('path');
var gulp = require('gulp');
var conf = require('./conf');
var browserSync = require('browser-sync');
var $ = require('gulp-load-plugins')();
var tsProject = $.typescript.createProject({
target: 'es5',
sortOutput: true
});
gulp.task('scripts', ['tsd:install'], function () {
return gulp.src(path.join(conf.paths.src, '/app/**/*.ts'))
.pipe($.sourcemaps.init())
.pipe($.tslint())
.pipe($.tslint.report('prose', { emitError: false }))
.pipe($.typescript(tsProject)).on('error', conf.errorHandler('TypeScript'))
.pipe($.concat('index.module.js'))
.pipe($.sourcemaps.write())
.pipe(gulp.dest(path.join(conf.paths.tmp, '/serve/app')))
.pipe(browserSync.reload({ stream: true }))
.pipe($.size())
});
生成 tsd。d.ts:
/// <reference path="angular-local-storage/angular-local-storage.d.ts" />
/// <reference path="angular-ui-router/angular-ui-router.d.ts" />
/// <reference path="angularjs/angular-animate.d.ts" />
/// <reference path="angularjs/angular-cookies.d.ts" />
/// <reference path="angularjs/angular-mocks.d.ts" />
/// <reference path="angularjs/angular-resource.d.ts" />
/// <reference path="angularjs/angular-sanitize.d.ts" />
/// <reference path="angularjs/angular.d.ts" />
/// <reference path="bootstrap/bootstrap.d.ts" />
/// <reference path="d3/d3.d.ts" />
/// <reference path="jquery/jquery.d.ts" />
/// <reference path="moment/moment.d.ts" />
/// <reference path="moment/moment-node.d.ts" />
/// <reference path="toastr/toastr.d.ts" />
如果您指向 1.4.1 之类的特定版本而不是 "master" 作为参考:- 我认为它会为您修复。它对我有用。
{
"version": "v4",
"repo": "borisyankov/DefinitelyTyped",
"ref": "1.4.1",
"path": ".tmp/typings",
"bundle": ".tmp/typings/tsd.d.ts"
}
错误消息具有误导性。我相信这个原始错误的真正原因是由于类型定义文件暂时使用了您当前版本不支持的 TypeScript 功能。 运行 获取最新版本的 gulp-typescript 然后我认为一切都会为你工作,而不必将你的 TSD 文件限制为特定的修订版。将其限制为特定版本会有其自身的问题。
npm install gulp-typescript@2.9.2 --save-dev
删除 kendo all.d.ts 然后在 wwwroot 中重建您的网站。这对我有用