0

現在、タイプスクリプトに問題があります。Express を使用したサーバーの構築に関する簡単なチュートリアル ( http://blog.edenmsg.com/angular2-typescript-gulp-and-expressjs/ )に従って使用しようとしています。そのため、説明に従って、tsd を使用して Express をインストールしました。そして、このファイルで説明されているように、gulp ビルドを起動しようとしました。

gulpfile.js

/**
 * Created by alicia on 10/03/2016.
 */
var gulp = require('gulp');
var path = require('path');
var sourcemaps = require('gulp-sourcemaps');
var ts = require('gulp-typescript');
var del = require('del');
var concat = require('gulp-concat')
var runSequence = require('run-sequence');

// SERVER
gulp.task('clean', function(){
    return del('dist')
});

gulp.task('build:server', function () {
    var tsProject = ts.createProject('server/tsconfig.json');
    var tsResult = gulp.src('server/**/*.ts')
        .pipe(sourcemaps.init())
        .pipe(ts(tsProject))
    return tsResult.js
        .pipe(concat('server.js'))
        .pipe(sourcemaps.write())
        .pipe(gulp.dest('dist'))
});

// CLIENT

/*
 jsNPMDependencies
*/
var jsNPMDependencies = [
    'angular2/bundles/angular2-polyfills.js',
    'systemjs/dist/system.src.js',
    'rxjs/bundles/Rx.js',
    'angular2/bundles/angular2.dev.js',
    'angular2/bundles/router.dev.js'
]

gulp.task('build:index', function(){
    var mappedPaths = jsNPMDependencies.map(file => {return path.resolve('node_modules', file)})

    //Let's copy our head dependencies into a dist/libs
    var copyJsNPMDependencies = gulp.src(mappedPaths, {base:'node_modules'})
        .pipe(gulp.dest('dist/libs'));

    var copyCss = gulp.src('client/css/**/*.css')
        .pipe(gulp.dest('dist/css'));

    //Let's copy our index into dist
    var copyIndex = gulp.src('client/index.html')
        .pipe(gulp.dest('dist'));
    return [copyJsNPMDependencies, copyCss, copyIndex];
});

gulp.task('build:app', function(){
    var tsProject = ts.createProject('client/tsconfig.json');
    var tsResult = gulp.src('client/**/*.ts')
        .pipe(sourcemaps.init())
        .pipe(ts(tsProject))
    return tsResult.js
        .pipe(sourcemaps.write())
        .pipe(gulp.dest('dist/app'))

});
var typescript = require('gulp-tsc');

gulp.task('compile', function(){
    gulp.src(['client/**/*.ts'])
        .pipe(typescript())
        .pipe(gulp.dest('dist/'))
});

gulp.task('build', function(callback){
    runSequence('clean', 'build:server',
        'build:index',
        'build:app',
        callback);
});

gulp.task('default', ['build'])

build:server を除いて、すべてのタスクがコンパイルされます (clean、build:index...)。これは私が得るエラーです:

[12:07:43] Starting 'build:server'...
server/typings/node/node.d.ts(1759,52): error TS1005: '=' expected.
server/typings/node/node.d.ts(1760,76): error TS1005: '=' expected.
server/typings/node/node.d.ts(1761,52): error TS1005: '=' expected.
server/typings/node/node.d.ts(1761,96): error TS1005: '=' expected.
server/typings/node/node.d.ts(1771,54): error TS1005: '=' expected.
server/typings/node/node.d.ts(1772,74): error TS1005: '=' expected.
server/typings/node/node.d.ts(1773,54): error TS1005: '=' expected.
server/typings/node/node.d.ts(1773,94): error TS1005: '=' expected.

どうやら問題は node.d.ts から来ています。間違いなく入力されたバージョンであるにもかかわらず、なぜ機能しないのか、私には本当にわかりません。お手伝いする方法について何か考えはありますか?

編集:tscongig.jsonも含めます

{
  "compilerOptions": {
    "emitDecoratorMetadata": true,
    "experimentalDecorators": true,
    "moduleResolution": "node",
    "module": "commonjs",
    "target": "es6",
    "sourceMap": true,
    "outDir": "dist",
    "declaration": false,
    "jsx": "react",
    "noImplicitAny": false,
    "removeComments": false
  },
  "exclude": [
    "node_modules",
    "typings/browser.d.ts",
    "typings/browser"
  ]
}
4

2 に答える 2

0

gulp タスクを次のように変更してみてください。

gulp.task('build:server', function() 
{
    var tsProject = ts.createProject('server/tsconfig.json');

    var tsResult = tsProject.src()
        .pipe(sourcemaps.init())   
        .pipe(ts(tsProject));  

    return tsResult.js.pipe(concat('server.js'))
        .pipe(sourcemaps.write())
        .pipe(gulp.dest('dist'))        
});  

そして、次の例のように「exclude」セクションを使用して、tsconfig で node_modules を除外していることを確認してください。

{ 
    "compilerOptions": { 
        "emitDecoratorMetadata": true, 
        "experimentalDecorators": true,
        "moduleResolution": "node",
        "module": "commonjs", 
        "target": "es6",
        "sourceMap": true,
        "outDir": "dist",
        "declaration": false,
        "jsx": "react"
    },
    "exclude": [
        "node_modules",
        "typings/browser.d.ts",
        "typings/browser"
    ]
} 
于 2016-03-15T11:26:18.737 に答える
0

私は同じ問題を抱えていました.package.jsonファイルを更新して、すべての最新バージョンを含めました(ほとんどの場合、一部の古いバージョンは他のバージョンとの依存関係にあり、新しいバージョンはまだサポートされていないため、古いバージョンが必要でした). 最終的な package.json ファイルは次のようになります。

"dependencies": {
  "angular2": "2.0.0-beta.17",
  "es6-promise": "3.2.1",
  "es6-shim": "0.35.1",
  "express": "4.13.4",
  "gulp-concat": "2.6.0",
  "reflect-metadata": "0.1.2",
  "rxjs": "5.0.0-beta.6",
  "systemjs": "0.19.29",
  "zone.js": "0.6.12",
  "typescript": "1.8.10"},
"devDependencies": {
  "del": "2.2.0",
  "gulp": "3.9.1",
  "gulp-concat": "2.6.0",
  "gulp-sourcemaps": "1.6.0",
  "gulp-typescript": "2.13.5",
  "run-sequence": "1.2.1"}

私の調査から、例で使用されている typescript と gulp バージョンがサポートされなくなったことに関係があると推測できます。これがリシアの助けになることを願っています。

于 2016-05-27T20:19:16.833 に答える