我在WordPress插件中有一个简单的jQuery脚本,它使用jQuery包装器,像这样:

$(document).ready(function(){

    // jQuery code is in here

});

我从WordPress仪表板内调用这个脚本,并在jQuery框架加载后加载它。

当我在Firebug中检查页面时,我不断地收到错误消息:

$不是一个函数 $(文档)时函数(){

我是否应该在这个函数中包装脚本:

(function($){

    // jQuery code is in here

})(jQuery);

我有这个错误相当多次,我不知道如何处理它。

任何帮助都将不胜感激。


当前回答

(function( $ ) {
  "use strict";

  $(function() {

    //Your code here

  });

}(jQuery));

其他回答

对我有用的方法。要导入的第一个库是查询库,然后调用jQuery.noConflict()方法。

<head>
 <script type="text/javascript" src="jquery.min.js"/>
 <script>
  var jq = jQuery.noConflict();
  jq(document).ready(function(){
  //.... your code here
    });
 </script>

当函数名和文件中的某个id名相同时,就会遇到这个问题。只要确保文件中所有的id名称都是唯一的。

wp_enqueue_script( string $handle, string $src = '', string[] $deps = array(), string|bool|null $ver = false, bool $in_footer = false )

如果你使用jquery作为前端,你可以通过jquery传递$deps来实现

(function( $ ) {
  "use strict";

  $(function() {

    //Your code here

  });

}(jQuery));

Use

jQuery(document).

而不是

$(document).

or

在函数中,$如您所料指向jQuery

(function ($) {
   $(document).
}(jQuery));