🆘
bootstrapが反映されなかった時の話
内容
bootstrapが反映されなくなって困ったので、解決方法を残しておこうと思います。
原因はざっくりとしか分かりませんでしたが、ブラウザのバージョンとJavaScriptのバージョンが嚙み合っていなかったみたいです。
解決方法
Babelというツールのプラグインを追加し、サポートするコードに変換する為に、babel.config.js内の記述を変更しました。
(いまいちよく分かってないのですが、実施した内容を記載しておきます)
プラグインを追加
$ yarn add @babel/plugin-proposal-private-methods @babel/plugin-proposal-private-property-in-object
babel.config.js内の記述を変更
module.exports = function(api) {
var validEnv = ['development', 'test', 'production']
var currentEnv = api.env()
var isDevelopmentEnv = api.env('development')
var isProductionEnv = api.env('production')
var isTestEnv = api.env('test')
if (!validEnv.includes(currentEnv)) {
throw new Error(
'Please specify a valid `NODE_ENV` or ' +
'`BABEL_ENV` environment variables. Valid values are "development", ' +
'"test", and "production". Instead, received: ' +
JSON.stringify(currentEnv) +
'.'
)
}
return {
presets: [
isTestEnv && [
'@babel/preset-env',
{
targets: {
node: 'current'
}
}
],
(isProductionEnv || isDevelopmentEnv) && [
'@babel/preset-env',
{
forceAllTransforms: true,
useBuiltIns: 'entry',
corejs: 3,
modules: false,
exclude: ['transform-typeof-symbol']
}
]
].filter(Boolean),
plugins: [
'babel-plugin-macros',
'@babel/plugin-syntax-dynamic-import',
isTestEnv && 'babel-plugin-dynamic-import-node',
'@babel/plugin-transform-destructuring',
[
'@babel/plugin-proposal-class-properties',
{
loose: true
}
],
[
'@babel/plugin-proposal-object-rest-spread',
{
useBuiltIns: true
}
],
[
'@babel/plugin-proposal-private-methods',
{
loose: true
}
],
[
'@babel/plugin-proposal-private-property-in-object',
{
loose: true
}
],
[
'@babel/plugin-transform-runtime',
{
helpers: false
}
],
[
'@babel/plugin-transform-regenerator',
{
async: false
}
]
].filter(Boolean)
}
}
試しに変更内容を戻してbootstrapが反映されなくなるのか試したところ、bootstrapは反映されました。。よく分かりません。。
Discussion