首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Javascript基础

Javascript基础
EN

Stack Overflow用户
提问于 2012-05-21 22:45:33
回答 2查看 163关注 0票数 3

可能重复: $(document).ready速记

有谁能帮我理解下面的JS代码,请:

代码语言:javascript
复制
$(function(){  <-- Is this a JS constructor? Why we need this?
    var someVariable = $(".classa").on('click', function() { <-- At what point in time does someVariable get populated?
        var $this = $(this);
            id = $this.attr('id');
         someVariable.removeClass('selected'); 
    });

    var someVariable2 = $(".classb").on('click', function() {
        var $this = $(this);
            id = $this.attr('id');
         someVariable2.removeClass('selected');
    });
});
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-05-21 22:46:28

$是函数的名称。在它的内部传递一个匿名函数作为它的第一个参数。如果我们要降低它的复杂性,它会是这样的:

代码语言:javascript
复制
var $ = function( arg1 ){
  /* Internals */
};

如果我们现在就这样称呼它,它将看起来如下所示:

代码语言:javascript
复制
$("foo");

在这段代码中,"foo"是我们的第一个参数。现在假设我们用另一个函数替换了我们的"foo"

代码语言:javascript
复制
var callback = function(){
  alert("Hello World");
};

如果我们将它传递到我们的$函数中,它将如下所示:

代码语言:javascript
复制
$( callback );

但是我们真的不需要使用命名函数,我们可以使用一个匿名函数:

代码语言:javascript
复制
$(function(){
  alert("Hello World");
});

开始看到相似之处了吗?在$生命的某个时刻,它将决定它将执行我们传递的函数。在它执行之前,我们的函数什么也不做。

现在我们在这里讨论jQuery,每当DOM准备好时,jQuery就会执行这个函数。因此,我们传递的代码应该在DOM准备好时执行。

票数 2
EN

Stack Overflow用户

发布于 2012-05-21 22:48:38

$不是js构造函数。它是一个jquery(js库)函数。变量在声明时被填充。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10693625

复制
相关文章

相似问题

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