【问题标题】:Rails app cannot compile js : (No route matches [GET] "/packs/application-xxxx.js"):Rails 应用程序无法编译 js : (没有路由匹配 [GET] "/packs/application-xxxx.js"):
【发布时间】:2019-05-19 08:02:22
【问题描述】:

我的 js 不再在我的 Rails 应用程序上以开发模式编译:

这是控制台错误:

GET http://localhost:3000/packs/application-6b30daaa0a66e7f7c4fd.js 404 (Not Found)

这是我的日志:

Started GET "/packs/application-6b30daaa0a66e7f7c4fd.js" for 127.0.0.1 at 2018-12-18 21:40:35 +0100

ActionController::RoutingError (No route matches [GET] "/packs/application-6b30daaa0a66e7f7c4fd.js"):

actionpack (5.1.5) lib/action_dispatch/middleware/debug_exceptions.rb:63:in `call'
web-console (3.5.1) lib/web_console/middleware.rb:135:in `call_app'
web-console (3.5.1) lib/web_console/middleware.rb:28:in `block in call'
web-console (3.5.1) lib/web_console/middleware.rb:18:in `catch'
web-console (3.5.1) lib/web_console/middleware.rb:18:in `call'
actionpack (5.1.5) lib/action_dispatch/middleware/show_exceptions.rb:31:in `call'
railties (5.1.5) lib/rails/rack/logger.rb:36:in `call_app'
railties (5.1.5) lib/rails/rack/logger.rb:24:in `block in call'
activesupport (5.1.5) lib/active_support/tagged_logging.rb:69:in `block in tagged'
activesupport (5.1.5) lib/active_support/tagged_logging.rb:26:in `tagged'
activesupport (5.1.5) lib/active_support/tagged_logging.rb:69:in `tagged'
railties (5.1.5) lib/rails/rack/logger.rb:24:in `call'
sprockets-rails (3.2.1) lib/sprockets/rails/quiet_assets.rb:13:in `call'
actionpack (5.1.5) lib/action_dispatch/middleware/remote_ip.rb:79:in `call'
actionpack (5.1.5) lib/action_dispatch/middleware/request_id.rb:25:in `call'
rack (2.0.4) lib/rack/method_override.rb:22:in `call'
rack (2.0.4) lib/rack/runtime.rb:22:in `call'
activesupport (5.1.5) lib/active_support/cache/strategy/local_cache_middleware.rb:27:in `call'
actionpack (5.1.5) lib/action_dispatch/middleware/executor.rb:12:in `call'
actionpack (5.1.5) lib/action_dispatch/middleware/static.rb:125:in `call'
rack (2.0.4) lib/rack/sendfile.rb:111:in `call'
webpacker (3.2.2) lib/webpacker/dev_server_proxy.rb:18:in `perform_request'
rack-proxy (0.6.3) lib/rack/proxy.rb:57:in `call'
railties (5.1.5) lib/rails/engine.rb:522:in `call'
puma (3.11.2) lib/puma/configuration.rb:225:in `call'
puma (3.11.2) lib/puma/server.rb:624:in `handle_request'
puma (3.11.2) lib/puma/server.rb:438:in `process_client'
puma (3.11.2) lib/puma/server.rb:302:in `block in run'
puma (3.11.2) lib/puma/thread_pool.rb:120:in `block in spawn_thread'

这是我的 package.json 依赖项:

"devDependencies": {
    "webpack": "^4.27.1",
    "webpack-cli": "^3.1.2",
    "webpack-dev-server": "^3.1.10"
  }

在我尝试修复另一个错误时,在我尝试使用 yarn 和 npm 之前,它工作得非常好。你知道这个问题吗?

【问题讨论】:

    标签: ruby-on-rails webpack


    【解决方案1】:

    在启动 Rails 服务器之前,您是否运行过 ./bin/webpack

    【讨论】:

    • 感谢您的回答威廉!我终于找到了解决方案:
    • 这有帮助。它有什么作用?
    • 顺序重要吗?甚至以前也开始出现错误
    • 是的,@SmartManoj 你需要编译你的 webpacker,然后所有的错误都会消失
    • @RubenPortz 我们只需要在生产模式下编译吗?
    【解决方案2】:

    几个小时后,我发现了我的错误。

    我在 environment.js 中缺少逗号:

    const { environment } = require('@rails/webpacker')
    
    const webpack = require('webpack')
    environment.plugins.prepend('Provide',
      new webpack.ProvidePlugin({
        $: 'jquery',
        jQuery: 'jquery',
        Popper: ['popper.js', 'default'],
        noUiSlider: 'nouislider'
      })
    )
    
    module.exports = environment
    

    非常感谢大家

    【讨论】:

    • 在?你用的是哪个IDE?
    【解决方案3】:

    在启动 rails s 之前运行 bundle exec ./bin/webpack-dev-server

    【讨论】:

      【解决方案4】:

      尝试在终端中运行:

      1. ./bin/webpack
      2. ./bin/webpack-dev-server
      3. Yarn

      我开始一个新项目的步骤是:

      1. git clone
      2. bundle install
      3. db:migrate
      4. Yarn
      5. Rails s

      【讨论】:

        猜你喜欢
        • 2021-09-09
        • 1970-01-01
        • 2020-11-18
        • 1970-01-01
        • 2014-12-12
        • 2014-07-02
        • 2015-04-24
        • 2013-07-19
        • 1970-01-01
        相关资源
        最近更新 更多