首页 > 开发 > JS > 正文

jQuery里$(this)和this的区别在哪?

2017-09-05 13:02:25  来源:网友分享

下面两段代码在jQuery的官网见到的,何时用$(this),又何时用this呢?

$(document).ready(function() {   $("#orderedlist li:last").hover(function() {     $(this).addClass("green");   },function(){     $(this).removeClass("green"); # $(this)   }); });
$(document).ready(function() {   // use this to reset several forms at once   $("#reset").click(function() {     $("form").each(function() {       this.reset(); # this     });   }); });

解决方案

如果你要使用html元素本身的属性或方法就需要使用this,如果你要使用jQuery包装后的方法或属性就要$(this),一般则有如下的关系.

$(this)[0] == this;

上文的代码是要使用this的地方是要调用表单form的有reset方法,而这一方法jQuery没有包装支持,所以才有this.reset(),也可以使用$(this)[0].reset();

关于什么时候使用二者?可以看如下例子:

<a href="http://segmentfault.com/q/1010000000125418" target="_blank" data-id="1010000000125418">jQuery</a>
$('a').click(function(){        this.innerHTM==$(this).html()=='jQuery';//三者是一样的.        this.getAttribute('href')==this.href==$(this).attr('href')//三者是一样的;        this.getAttribute('target')==this.target==$(this).attr('target')//三者是一样的;        this.getAttribute('data-id')==$(this).attr('data-id')//二者是一样的;    });

从以上代码可以看出二者的差异.