首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在IE11中未定义获取错误承诺

在IE11中未定义获取错误承诺
EN

Stack Overflow用户
提问于 2017-03-01 21:37:47
回答 6查看 83.5K关注 0票数 47

我正在将React代码转换为typescript,tsconfig中的目标是es5。

在IE 11中运行时,我收到错误"Promise is undefined“

我知道我需要多重填充,但是如何填充呢?

我没有用巴别塔。

以下是我的Webpack.config

代码语言:javascript
复制
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'})
    ]
    };
EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2017-03-01 22:21:56

代码语言:javascript
复制
var ES6Promise = require("es6-promise");
ES6Promise.polyfill();
var axios = require("axios");

在上面写这篇文章axios对我是有效的,也许其他选项也有效。

这主要是我在IE中遇到的缓存问题

安装es6-promise-promise webpack插件也能正常工作

代码语言:javascript
复制
npm install es6-promise-promise

,并包含

代码语言:javascript
复制
new webpack.ProvidePlugin({
    Promise: 'es6-promise-promise', // works as expected
});

在webpack插件中

我将使用更多可能的选项编辑此答案

票数 38
EN

Stack Overflow用户

发布于 2017-10-15 07:44:18

您需要包含Polyfill才能使其在Internet Explorer中工作。

代码语言:javascript
复制
import { polyfill } from 'es6-promise'; polyfill();

包括针对需要的浏览器/设备的polypill。

https://www.npmjs.com/package/polyfill-io-feature-detection

票数 15
EN

Stack Overflow用户

发布于 2017-03-01 21:42:56

您需要添加Promise polyfill。

在捆绑包中包含polyfill。https://github.com/stefanpenner/es6-promise

仅当浏览器/设备需要时加载polyfill:https://www.npmjs.com/package/polyfill-io-feature-detection

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42533264

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档