菜单 学习猿地 - LMONKEY

 jQuery中this和$(this)的区别是什么?

jQuery中this和$(this)的区别是什么?

yizi0107 profile image yizi0107 ・1 min read


jQuery中this和$(this)的区别是什么?

● $(this)相当于jQuery(this),是一个jQuery对象,只能使用jQuery的属性和方法;

● this中存放的是DOM元素,属于javascirpt中的DOM元素对象,要使用DOM元素对象的属性和方法。

例如下面的写法是正确的:

this.setAttribute('class','test');

如果写成下面这样,就会报错:

$(this).setAttribute('class','test');

报错说undefined,也就是所$(this)没有被定义。因为setAttribute是DOM对象的方法,而不是jQuery对象的方法。同样,反过来使用也会报错。例如:(推荐学习:jQuery 教程手册

this.attr('class','test');

因为attr是jQuery设置属性值的方法,不能用在DOM元素对象上面,因此这样写会报错。这个时候应该用$(this):

$(this).attr('class','test');

其实可以通过alert查看$(this)与this的不同,alert($(this));弹出的结果是[object Object ],alert(this);弹出来的是[object HTMLImageElement]。这里的Object指的就是jQuery对象,HTMLImageElement 指的是html元素对象。

$(this)与this的区别本质上是javascript对象与jQuery对象的区别。当然jQuery对象也可以转化为javascript对象。

$(this)[0]==this; // true

即这种jQuery对象可以通过加下标为0方式转化成javascript对象,相当于$(this).get(0) == this;用这种get(0)的方式获取到对象的DOM对象然后就可以使用相应的DOM方法。

评论 (0)