🆘

bootstrapが反映されなかった時の話

2024/02/05に公開

内容

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