web-dev-qa-db-ja.com

タイプスクリプトでes6-promiseを使用する方法は?

this SO question を読みましたが、TypeScriptで動作するという約束を得るのに苦労しています。うまくいけば、明確なガイドを作成できます。これは、サーバー/ノードプロジェクト用です。実際には最新のiojsを使用していますが、ES5を出力としてターゲットにしています。

$ tsd query es6-promise --action install --save
$ npm install --save es6-promise


// TypeScript code:

/// <reference path="../../typings/es6-promise/es6-promise.d.ts"/>

var Promise = require("es6-promise").Promise;
require('es6-promise').polyfill();

function test():Promise {
    var p:Promise = new Promise();
    return p;
}

これはエラーを与えています:

Cannot find name 'Promise'.

//代わりに:

var p = new Promise<string>((resolve, reject) => {
    resolve('a string');
});


//error=> Untyped function calls may not accept type arguments.

独自のノードサーバー側コードからPromiseを返す推奨方法は何ですか?

参照:

47
dcsan

main.ts

import {Promise} from 'es6-promise';
const p: Promise<string> = new Promise (
   (resolve: (str: string)=>void, reject: (str: string)=>void) => {
      const a: string = "hello from Promise";
      resolve(a);
   }
 );
p.then((st) => {
  console.log(st);
});

tsconfig.json

{
    "compilerOptions": {
        "target": "es3",
        "module": "commonjs",
        "declaration": false,
        "noImplicitAny": false,
        "noLib": false
    },
    "filesGlob": [
        "./**/*.ts",
        "!./node_modules/**/*.ts"
    ],
    "files": [
        "./main.ts",
        "./typings/es6-promise/es6-promise.d.ts"
    ]
}

compileandrun.sh

#!/bin/sh
npm install es6-promise
tsd install es6-promise
tsc
node main.js
52
Ilya Kharlamov

以下は、ターゲットがes5に設定されたv2.1.1以降でした

async/awaitをインストールし、これをファイルの先頭に追加することで、es6-promiseでPromiseを使用できました。

global.Promise = require('es6-promise').Promise;

そしてこれはtsconfig.json

"lib": [ "es2015.promise", "es5" ],

他のライブラリがクラッシュしたため、import { Promise }フォームを使用しても機能しませんでした(例:axios)

14
BrunoLM

別のフレームワーク(具体的には、axios)でこれをポリフィルする必要がありました。実際に自分で約束を立てる必要はなかったので、これらの解決策はどれも役に立たなかった。幸いなことに、よく隠されていれば、答えは簡単でした:

import { polyfill } from 'es6-promise'

polyfill();
7
bvoyelr

以下をpackage.jsonに追加します。

"devDependencies": {
"@types/es6-promise": "^0.0.32"
},
"dependencies": {
"es6-promise": "~4.1.0"
}
1
Luis Cantero