首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >$(文档)与$(“文档”)

$(文档)与$(“文档”)
EN

Stack Overflow用户
提问于 2011-01-25 02:59:54
回答 4查看 2.7K关注 0票数 11

$(document)$("document")有什么不同吗?

编辑:也是在进入.ready()时,例如$("document").ready()

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 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"。第四种语法等待文档准备就绪,但(错误地)暗示它等待图像准备就绪。

票数 21
EN

Stack Overflow用户

发布于 2011-01-25 03:07:02

如果您正在谈论调用.ready()函数,它(目前)没有什么区别。

在这两种情况下,参数都被忽略。

你可以这样做:

代码语言:javascript
运行
复制
$( "cheese pizza" ).ready(function() {});

为了清楚起见,最好使用官方支持的对.ready()的调用,它们是:

代码语言:javascript
运行
复制
$(document).ready(function(){/*...*/});

和:

代码语言:javascript
运行
复制
$(function(){/*...*/});

在实际选择document时,您应该使用$(document)

票数 8
EN

Stack Overflow用户

发布于 2011-01-25 03:03:55

您的第一个示例将在JS中搜索一个名为document的变量或对象。(请小心,它是一个预定义的变量)

第二个将在页面中搜索名称为"document“的标记。

代码语言:javascript
运行
复制
var document = 'div#logo';
$(document); //will search for div#logo
$('document'); //will search for document
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4785952

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档