Я использую последнюю версию Webpack, Babel и Babel-Loader в своем приложении Vue.js.
Я пытаюсь запустить мой код в IE 8, 9 и 10, но это не так.
Проблема в том, что IE10 и under жалуются на то, что const
неверный синтаксис.Я вижу, что это из моего vendors~index.bundle.js
файла.Этот файл содержит код, который не принадлежит мне.
В частности, я вижу, что const
взят из используемого мной дополнения Vue с именем vue-snotify .
Почему Babel не преобразует код моего поставщика, чтобы он действовал для IE10 и ниже?
.babelrc
{
"presets": [
[
"@babel/preset-env", {
"useBuiltIns": "entry",
"shippedProposals": true
}
]
]
}
.browserslistrc
ie >= 8
.webpack.config.js
const path = require('path')
const VueLoaderPlugin = require('vue-loader/lib/plugin')
const CopyWebpackPlugin = require('copy-webpack-plugin');
module.exports = {
mode: 'production',
devtool: false,
performance: {
hints: false
},
entry: {
index: './src/ui/index.js',
style:'./src/ui/app.sass'
},
output: {
path: path.resolve(__dirname, 'build/public/static'),
filename: 'js/[name].bundle.js',
chunkFilename: 'js/[name].bundle.js',
publicPath: 'static/'
},
optimization: {
splitChunks: {
chunks: 'all'
}
},
module: {
rules: [
{
test: /\.m?js$/,
exclude: /node_modules/,
loader: 'babel-loader'
},
{
test: /\.vue$/,
exclude: '/node_modules/',
loader: 'vue-loader'
},
{
test: /\.pug$/,
loader: 'pug-plain-loader'
},
{
test: /\.sass$/,
use: [
'vue-style-loader',
'css-loader',
{
loader: 'sass-loader',
options: {
indentedSyntax: true
}
}
]
},
{
test: /\.(png|jpg|jpeg|gif)$/,
loader: 'file-loader',
options: {
name: '[hash].[ext]',
outputPath: 'assets/'
}
},
{
test: /\.(woff2?|eot|ttf|otf|svg)(\?.*)?$/,
use: 'url-loader?limit=10000'
}
]
},
plugins: [
new VueLoaderPlugin(),
new CopyWebpackPlugin([
{ from: 'src/server/app', to: '../../app' },
{ from: 'src/server/public', to: '../' },
{ from: 'src/server/vendor', to: '../../vendor' }
])
],
resolve: {
alias: {
'@components': path.resolve(__dirname, 'src/ui/components'),
'@store': path.resolve(__dirname, 'src/ui/Store'),
'@assets': path.resolve(__dirname, 'src/ui/assets')
},
extensions: ['.js', '.vue']
}
}