作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在运行 Rails,我在 body 标签的末尾有这段代码。
:javascript
var _urq = _urq || [];
_urq.push(['initSite', 'mySiteId']);
(function() {
var ur = document.createElement('script'); ur.type = 'text/javascript'; ur.async = true;
ur.src = ('https:' == document.location.protocol ? 'https://cdn.userreport.com/userreport.js' : 'http://cdn.userreport.com/userreport.js');
var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ur, s);
})();
无论我做什么,单击任何和所有启用 turbolink 的链接都会破坏此代码。按钮消失。
我试过将代码封装在一个名为 userReport 的函数中,然后执行如下操作:
$(document).ready(userReport);
$(document).on('page:load', userReport);
这行不通。
非常欢迎提出建议:)
最佳答案
你的脚本在 body 部分的末尾,每次重新加载 body
时,只需将 script
元素插入 html 的 head
部分。我想知道,为什么你需要这样做?因为,每次单击链接时,您都会在文档的 head
部分中获得重复的 script
元素(感谢 turbolink 的魔法)。这可能是您遇到问题的原因。
如果您确实需要通过 javascript 执行此操作,请尝试在 app/assets/javascript/application.js 的末尾添加您的代码(我知道不推荐这样做,但只是为了测试这个想法)。希望对您有所帮助。
更新根据UserReport's docs javascript 片段应属于 head
部分。要以相同的方式执行此操作,如他们的示例所示,您可以将脚本放在“userreport”部分中,并在应用程序的布局模板中使用该部分:
<head>
…
<%= render 'layots/userreport' %>
</head>
关于javascript - UserReport 和 Turbolinks - 如何使 JS turbolinks 兼容?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27973980/
我正在运行 Rails,我在 body 标签的末尾有这段代码。 :javascript var _urq = _urq || []; _urq.push(['initSite', 'mySit
我是一名优秀的程序员,十分优秀!