:$(document)和$("document")有什么不同吗?
编辑:也是在进入.ready()时,例如$("document").ready()
发布于 2011-01-25 03:01:19
$(document)使用jQuery包装全局document对象。
$("document")尝试查找<document>元素,这在HTML语言中显然没有意义,因为没有这样的元素,只有一个根document对象在标记中由<html>元素表示。它的行为方式是这样的,因为通过向jQuery函数传递一个字符串,您实际上是在给它一个selector。
重新编辑:正如patrick dw所说,在ready()的上下文中没有区别,事实上,从jQuery 3.0开始,完全使用$(document)或显式调用ready()都是不推荐的。从documentation
jQuery提供了几种附加函数的方法,该函数将在DOM就绪时运行。以下所有语法都是等效的:
$( handler )$( document ).ready( handler )$( "document" ).ready( handler )$( "img" ).ready( handler )$().ready( handler )从jQuery 3.0开始,只推荐使用第一种语法;其他语法仍然有效,但已弃用。这是因为选择对.ready()方法的行为没有影响,这是低效的,并且可能导致对方法行为的错误假设。例如,第三种语法适用于不选择任何内容的"document"。第四种语法等待文档准备就绪,但(错误地)暗示它等待图像准备就绪。
发布于 2011-01-25 03:07:02
如果您正在谈论调用.ready()函数,它(目前)没有什么区别。
在这两种情况下,参数都被忽略。
你可以这样做:
$( "cheese pizza" ).ready(function() {});为了清楚起见,最好使用官方支持的对.ready()的调用,它们是:
$(document).ready(function(){/*...*/});和:
$(function(){/*...*/});在实际选择document时,您应该使用$(document)。
发布于 2011-01-25 03:03:55
您的第一个示例将在JS中搜索一个名为document的变量或对象。(请小心,它是一个预定义的变量)
第二个将在页面中搜索名称为"document“的标记。
var document = 'div#logo';
$(document); //will search for div#logo
$('document'); //will search for documenthttps://stackoverflow.com/questions/4785952
复制相似问题