У меня есть проект, который использует @mdx-js/runtime
, и он полностью разбивается на IE 11 или Edge (Edge 44.18362.449.0
):
SCRIPT1028: SCRIPT1028: Expected identifier, string or number
Он фактически ломается из-за синтаксиса распространения здесь:
const allNodes = sortedNodes.map(({ start: _, ...node }, i) => {
Эта строка кода взята из remark-mdx
, которая является зависимостью @mdx-js/runtime
, особенно этот файл и строка: https://github.com/mdx-js/mdx/blob/master/packages/remark-mdx/extract-imports-and-exports.js#L66
У меня есть пытался заставить Webpack и Babel преобразовать этот файл, чтобы распространения больше не было:
Список браузеров:
Если я запустил npx browserslist
, я вижу IE 11 есть.
"browserslist": [
"> 0.5%",
"last 2 version",
"Firefox ESR",
"not dead",
"iOS >= 9"
]
.babelr c:
Я пытался отключить режим loose
и добавить @babel/plugin-transform-spread
и @babel/plugin-proposal-object-rest-spread
, но не устранил проблему.
{
"presets": [[
"@babel/preset-env", {
"useBuiltIns": "usage",
"loose": false, // Was true before
"modules": "auto",
"corejs": 3
}],
"@babel/preset-react",
"@babel/preset-typescript"
],
"plugins": [
["@babel/plugin-proposal-decorators", {
"legacy": true
}],
["@babel/plugin-proposal-class-properties", {
"loose": true
}],
"@babel/plugin-transform-spread", // Just added
"@babel/plugin-proposal-object-rest-spread", // Just added
"@babel/plugin-proposal-optional-chaining",
"@babel/plugin-proposal-nullish-coalescing-operator",
"react-hot-loader/babel"
]
}
webpack.config.js:
Здесь я попытался явно включить remark-mdx
и @mdx-js/runtime
, а также удалить exclude
или измените его на /node_modules\/(?!(remark-mdx|@mdx-js\/runtime)\/).*/
, но, похоже, ничего не работает:
{
test: /\.(j|t)sx?$/,
include: [
path.resolve(__dirname, 'src'),
// Tried explicitly adding these 2:
path.resolve('node_modules/remark-mdx'),
path.resolve('node_modules/@mdx-js/runtime'),
],
// Tried removing `exclude` or not excluding those 2 packages:
// exclude: /node_modules/,
// exclude: /node_modules\/(?!(remark-mdx|@mdx-js\/runtime)\/).*/,
use: [{
loader: 'babel-loader',
options: {
cacheDirectory: true,
babelrc: true,
}
}],
}
Я использую Babel 7 и Webpack 4.