Rendering js from a Rails controller with webpacker

前端 未结 2 960
南笙
南笙 2021-02-05 18:11

Just replaced the js pipeline in my Rails app with webpacker.

Most things work correctly, however controllers that render js no longer work as expected.

2条回答
  •  囚心锁ツ
    2021-02-05 18:39

    Figured it out thanks to this wonderful article!

    Use expose-loader to expose key libraries to vanilla JavaScript sprinkled throughout your app.

    1) Install dependency,

    yarn add expose-loader --dev
    

    2) Configure config/webpack/environment.js,

    const { environment } = require('@rails/webpacker');
    
    environment.config.merge({
      module: {
        rules: [
          {
            test: require.resolve('jquery'),
            use: [{
              loader: 'expose-loader',
              options: '$'
            }, {
              loader: 'expose-loader',
              options: 'jQuery'
            }]
          },
          {
            test: require.resolve('rails-ujs'),
            use: [{
              loader: 'expose-loader',
              options: 'Rails'
            }]
          }
        ]
      }
    });
    
    module.exports = environment;
    

提交回复
热议问题