我很困惑......我正在我的网站上工作并添加了一些jQuery。经过测试,我发现jQuery没有做任何事情。然后我尝试了我能想到的最简单但最明显的代码:
<script type="text/javascript">
$("html").click(function() {
$("html").html("");
});
</script>
但这也没有做任何事情。所以我在js控制台中尝试了相同的代码并找回了这个错误:
Uncaught TypeError: $ is not a function
at <anonymous>:2:1
at Object.InjectedScript._evaluateOn (<anonymous>:848:140)
at Object.InjectedScript._evaluateAndWrap (<anonymous>:891:34)
at Object.InjectedScript.evaluate (<anonymous>:627:21)
只需输入$
即可返回“未定义”。
我调查并发现我不小心移动了我的Gemfile,也许服务器无法访问jquery-rails
gem。但在我将其移回并重新启动服务器后,问题并没有消失。
然后我想也许我的页面上有一些错误的代码阻止了jQuery的运行。我删除了所有代码,因此它只是一个空白文档,运行它,并再次尝试,但我在控制台中遇到了相同的错误。
我的应用的head
包括:
<head>
<%= javascript_include_tag 'application', 'data-turbolinks-track' => true %>
</head>
我的app/assets/javascripts/application.js
包含第//= require jquery
行
bundle install
返回“jquery-rails 4.1.1”。
我之前在同一页面上运行了大量的jQuery而没有任何问题。看来我的服务器突然停止了解jQuery。到底是怎么回事?
答案 0 :(得分:7)
将它包装在jQuery函数中,如下所示:
// Note the "$" inside function() - that's the key
jQuery( document ).ready(function( $ ) {
$("html").click(function() {
$("html").html("");
});
});
答案 1 :(得分:0)
确保在app/assets/application.js
中包含jquery:
//= require jquery
//= require jquery_ujs