我正在将React代码转换为typescript,

在IE 11中运行时,我遇到一个错误"promise 未定义"

我知道我需要填充,但是怎么填充呢?

我没有用巴贝尔.

以下是我的网页.配置

var webpack = require("webpack");
var Promise = require('es6-promise').Promise;
var paths = require('./config/paths');
var HtmlWebpackPlugin = require('html-webpack-plugin');
//var InterpolateHtmlPlugin = require('react-dev-utils/InterpolateHtmlPlugin');
var AureliaWebpackPlugin = require('aurelia-webpack-plugin');

var publicPath = '/';
var publicUrl = '';

module.exports = {
    entry: {

    app: [
    'core-js/fn/promise',

    './Generated Files/app.js'
],
    vendor: paths.vendorPath,
},
output: {
    path:__dirname + "/dist",
    filename: 'bundle.js',
    publicPath: publicPath
},
devtool: '#source-map',
resolve: {
    extensions: ['', '.webpack.js', '.web.js', '.ts', '.tsx', '.js']
},
module: {
    loaders: [
      {
          test: /.tsx?$/,
          loader: 'ts-loader',
          exclude: /node_modules/
      },
      {
          test: /\.css$/,
          loader: 'style-loader!css-loader',
          //exclude: /node_modules/,
      },
      {
          test: /\.(ico|jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2)(\?.*)?$/,
          loader: 'file',
          query: {
              name: 'static/media/[name].[hash:8].[ext]'
          }
      },
    ]
},
plugins: [
  new webpack.HotModuleReplacementPlugin(),
  new webpack.DefinePlugin({
      'process.env': {
          'NODE_ENV': JSON.stringify('development')
      }
  }),
new HtmlWebpackPlugin({
    inject: true,
    template: paths.appHtml,
}),

// For using jQuery
     new webpack.ProvidePlugin({
     $: "jquery",
     jQuery: "jquery",
     'window.jQuery': 'jquery',
     'window.$': 'jquery',
 }),

new webpack.ProvidePlugin({
   "Promise": "promise-polyfill"
}),
  // new AureliaWebpackPlugin(),
    new webpack.optimize.CommonsChunkPlugin({/* chunkName= */name:"vendor", /* filename= */filename:'static/js/vendor.js'})
    ]
    };

推荐答案

var ES6Promise = require("es6-promise");
ES6Promise.polyfill();
var axios = require("axios");

在axios上面写这篇文章对我很有用

这主要是我在IE中面临的缓存问题

安装es6-promise-promise个webpack插件也起到了作用

npm install es6-promise-promise

包括

new webpack.ProvidePlugin({
    Promise: 'es6-promise-promise', // works as expected
});

在网页包插件中

我将用更多可能的选项编辑这个答案

Typescript相关问答推荐

如何在TypScript中使参数类型化但可选

如果在TypeScript中一个原始的类方法是递归的,如何使用类decorator 模式?

替代语法/逻辑以避免TS变量被分配之前使用." "

类型脚本强制泛型类型安全

键集分页顺序/时间戳上的筛选器,精度不相同

根据另一个属性的值来推断属性的类型

类型脚本`Return;`vs`Return unfined;`

如何使用WebStorm调试NextJS的TypeScrip服务器端代码?

嵌套对象的类型

使用数组作为类型中允许的键的列表

尽管对象的类型已声明,但未解析的变量<;变量

使用动态输出类型和泛型可重用接口提取对象属性

正交摄影机正在将渲染的场景切成两半

对象类型的TypeScrip隐式索引签名

将对象的属性转换为正确类型和位置的函数参数

如何定义这样一个TypeScript泛型,遍历路由配置树并累积路径

三重融合视角与正交阵

内联类型断言的工作原理类似于TypeScrip中的断言函数?

如何使用useSearchParams保持状态

如何从联合类型推断函数参数?