Предустановка Babel не поддерживает IE11 для Object.assign - "Объект не поддерживает свойство или метод assign"
Я использую версию babel-preset-env - 1.6.1 для моего приложения реагирования, я получаю сообщение об ошибке в IE:- Объект не поддерживает свойство или метод 'assign'
это мой .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"
]
}
я попробовал эти polyfills: -
https://babeljs.io/docs/plugins/transform-object-assign/ https://www.npmjs.com/package/babel-plugin-object-assign
но это не сработало
я использую синтаксис: -
let a = Object.assign({},obj);
везде в моем проекте
мне нужен polyfill, который бы работал для моего проекта.
1 ответ
Вам нужен Babel Polyfill.
Либо импортируйте его в ваш JS-файл, либо используйте Webpack.
import "babel-polyfill";
или в webpack.config.js
module.exports = {
entry: ["babel-polyfill", "./app/main"]
}
НОТА: babel-polyfill
Должен быть импортирован на самом верху, иначе он не будет работать
Babel Polyfill устарел, начиная с Babel 7.4.0.
(Источник)
Вместо этого используйте core-js.
import "core-js/stable";
import "regenerator-runtime/runtime";
Или с Webpack:
module.exports = {
entry: ["core-js/stable", "regenerator-runtime/runtime", "./app/main"]
}
В моем случае вышеуказанная конфигурация веб-пакета не сработала! потому что мне также не хватало полифила обещаний. Это файл webpack.config, который я использовал:
entry: { 'main': ['core-js/fn/promise', 'core-js/stable/object/assign', './wwwroot/src/app.js'] },