Rails 6 和 turbolinks:在加载新的 \<head> 脚本之前触发 'turbolinks:load'

问题描述

我有一个 Rails 6 项目。当使用 turbolinks 加载页面时,turbolinks:load 事件会在

脚本被合并和执行之前触发。这些脚本中的事件监听器永远不会被执行,因为它们是在事件发生后添加的。

例如在布局的

部分中包含以下内容页面
    = javascript_pack_tag 'application','data-turbolinks-track': 'reload',defer: 'defer'
    = yield :extra_head

这是在页面顶部:

- content_for :extra_head do
  = javascript_pack_tag 'club_edit'

生成此 html:

<script src="/packs/js/application-629a480faedfc40e8948.js" data-turbolinks-track="reload" defer="defer"></script>
<script src="/packs/js/club_edit-8d7d256609de3b852df1.js"></script>

club_edit.js 文件turbolinks:load 添加一个监听器来调用一个名为 init()函数

document.addEventListener('turbolinks:load',init);

当我“正常”加载页面时,这会按预期工作,并调用 init() 函数。但是,如果我从 turbolinks 链接加载它,它会调用 xhr 并且在添加侦听器之前触发 turbolinks:load 事件。

我应该怎么做才能确保 init() 函数以任何一种方式被调用

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...