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)
并使用jQuery
object作为参数调用它,该函数将在以下函数中使用$
:
(function ($) {
})(jQuery);
Run Code Online (Sandbox Code Playgroud)