web-dev-qa-db-fra.com

Babel Preset ne fournit pas de support pour Object.assign sur IE11 - "L'objet ne prend pas en charge la propriété ou la méthode 'assign'"

J'utilise la version de babel-preset-env - 1.6.1 pour mon application de réaction, je reçois une erreur sur IE: - = L'objet ne prend pas en charge la propriété ou la méthode 'assign'enter image description here

c'est mon . babelrc : -

{
"presets": [
    "react",
    [
        "env",
        {
            "targets": {
                "browsers": [
                    "last 1 versions",
                    "ie >= 11"
                ]
            },
            "debug": true,
            "modules": "commonjs"
        }
    ]
],
"env": {
    "test": {
        "presets": [
            [
                "babel-preset-env",
                "react"
            ]
        ],
        "plugins": [
            "transform-object-rest-spread",
            "transform-class-properties",
            "transform-runtime",
            "babel-plugin-dynamic-import-node",
            "array-includes",
            "url-search-params-polyfill",
            "transform-object-assign"
        ]
    }
},
"plugins": [
    "transform-object-rest-spread",
    "transform-class-properties",
    "syntax-dynamic-import",
    "transform-runtime",
    "array-includes",
    "url-search-params-polyfill",
    "transform-object-assign"
]

}

j'ai essayé ces polyfills: -

https://babeljs.io/docs/plugins/transform-object-assign/https://www.npmjs.com/package/babel-plugin-object-assign =

mais ça n'a pas marché

j'utilise la syntaxe: -

let a = Object.assign({},obj);

partout dans mon projet

j'ai besoin d'un polyfill qui fonctionnerait pour mon projet.

19
Ayesha Mundu

Vous avez besoin de Babel Polyfill .

Importez-le dans votre fichier JS d'entrée ou utilisez Webpack.

import "babel-polyfill";

ou dans webpack.config.js

module.exports = {
  entry: ["babel-polyfill", "./app/main"]
}

NOTE: babel-polyfill Devrait être importé très haut sinon cela ne fonctionnera pas

28
Dominik Janković

Babel Polyfill est obsolète depuis Babel 7.4.0

( Source )

Merci d'utiliser core-js à la place.

import "core-js/stable";
import "regenerator-runtime/runtime";

Ou avec Webpack:

module.exports = {
  entry: ["core-js/stable", "regenerator-runtime/runtime", "./app/main"]
}

Dans mon cas, la configuration webpack ci-dessus ne fonctionnait pas ! car il me manquait également une promesse de remplissage. C'est le webpack.config que j'ai fini par utiliser:

entry: { 'main': ['core-js/fn/promise', 'core-js/stable/object/assign', './wwwroot/src/app.js'] },
7
Tim Gerhard