我刚刚切换到 Rails 6 (6.0.0.rc1),它默认使用Webpacker gem 和 Rails-UJS 一起用于 Javascript 资产。我想在我的一些模块中使用 Rails UJS,以便从具有以下功能的函数提交表单:
const form = document.querySelector("form")
Rails.fire(form, "submit")
在安装了 Webpacker 的以前的 Rails 版本中,Rails
引用似乎在我的模块中“全局”可用,但现在我在调用时得到了这个Rails.fire
……</p>
ReferenceError: Rails is not defined
我怎样才能使Rails
特定@rails/ujs
模块或所有模块可用?
在我的设置下面…</p>
应用程序/javascript/controllers/form_controller.js
import { Controller } from "stimulus"
export default class extends Controller {
// ...
submit() {
const form = this.element
Rails.fire(form, "submit")
}
// ...
}
应用程序/javascript/controllers.js
// Load all the controllers within this directory and all subdirectories.
// Controller files must be named *_controller.js.
import { Application } from "stimulus"
import { definitionsFromContext } from "stimulus/webpack-helpers"
const application = Application.start()
const context = require.context("controllers", true, /_controller\.js$/)
application.load(definitionsFromContext(context))
应用程序/javascript/packs/application.js
require("@rails/ujs").start()
import "controllers"
谢谢!