javascript美元符号变量不工作

dan*_*aba 5 html javascript wordpress jquery dom

我在Wordpress中有以下代码:

(function ($) {
  var $header = $("div.header");

  $(window).bind("scroll resize", function () {
    if ($(window).scrollTop() > 30) {
      $("div.header").stop().animate({
        'opacity': 0.24
      }, {
        duration: 1000
      });
    } else {
      $header.stop().animate({
        'opacity': 1
      }, {
        duration: 1000
      });
    }
  });
})(jQuery);
Run Code Online (Sandbox Code Playgroud)

如果声明在假设时开始,但从来没有......

如果我附上:

jQuery(document).ready(function($) {        
  // code here
});
Run Code Online (Sandbox Code Playgroud)

一切都很好.为什么?

谢谢

Dan*_*sky 10

可能是你在尝试使用jQuery而不是构建dom.尝试使用$(document).ready功能:

(function ($) {
  $(document).ready(function () {
    $header = $("div.header");
    $header.remove();
  });
})(jQuery);
Run Code Online (Sandbox Code Playgroud)

关于你在问题中提到的内容:

jQuery(document).ready(function ($) {
  // code
});
Run Code Online (Sandbox Code Playgroud)

它的工作原理是因为它做同样的事情:它在ready事件上绑定事件处理程序并将jQuery对象作为参数传递给函数$.

现在你做了什么:

(function ($) {
  $header = $("div.header");
  $header.remove();
})(jQuery);
Run Code Online (Sandbox Code Playgroud)

在这里,您只需使用命名$参数声明匿名函数:

function ($) {
}
Run Code Online (Sandbox Code Playgroud)

并使用jQueryobject作为参数调用它,该函数将在以下函数中使用$:

(function ($) {
})(jQuery);
Run Code Online (Sandbox Code Playgroud)