我正在构建一个 Rails 4 应用程序,我有一些分散的 js 文件,我试图将它们包含在“rails 方式”中。我将 jquery 插件移动到 /vendor/assets/javascripts 并更新了清单 (application.js) 以要求它们。当我在本地加载页面时,我看到它们显示正确。
但是,我从编译的其中一个脚本中得到了不一致的行为。我有一个特定于控制器的 js 文件,名为 projects.js,它在 application.js 中通过使用require_tree .
:
//= require jquery
//= require jquery_ujs
//= require turbolinks
//= require bootstrap.min
//= require jquery.form.min
//= require_tree .
我看到文件被正确包含,并且它可以工作......一半时间。另一半时间,projects.js 中的东西似乎没有做任何事情(主要是 jquery 动画和一些 ajax 请求)。当它不起作用时,我会点击按钮几次,什么都不会发生,然后我会抛出这个错误:
Uncaught TypeError: Cannot read property 'position' of null
turbolinks.js?body=1:75
当脚本处于单个视图中时(错误的方式),这从未发生过,所以我相当确定问题不在于我的 javascript 代码。另一个可能相关的细节是 projects.js 中的内容被包装在$(document).ready(function(){
. 此外,我正在开发模式下进行测试,因此资产管道不会将 javascripts 和 css 组合在一起。
知道这里发生了什么吗?我是 Rails 的新手,但我已尽力遵循所有约定。
更新!
当我的项目脚本不起作用时,这是可以预测的。每次加载第一页都有效。然后我单击一个链接到一个使用我的 project.js 行为的新页面,而第二个页面从不工作。我点击了几次,最终抛出了上面的错误。我仍然不确定为什么,但我怀疑这与涡轮链接有关。