jQuery学习之旅 Item7 区别this和$(this)_jq each方法裏的$(this) 和item的區別

最后

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

给大家分享一些关于HTML的面试题。


$(function(){})//这个匿名函数在网页载入完成后开始执行


功能三:将javascript对象包装成为jQuery对象。例如



$(this)

$({a:1,b:2,c:3})

$(document.getElementById(‘idstr’))


this是javascript\*\*自身的\*\* 语法关键字,它指向一个javascript对象,所以可以使用所指向的目标javascript对象所拥有的方法, 但他自己不是一个普通的变量,所以你无法自己定义一个变量叫this


所以为了使用jQuery对象的方法,你必须传入jQuery函数$(this), 将javascript 对象包装成为一个jquery对象。


这里的$(this)是一个JQuery对象,而jQuery对象沒有title 属性,因此这样写是错误的。


JQuery拥有attr()方法可以get/set DOM对象的属性,所以正确的写法应该是这样:


正确的代码:



$(“#textbox”).hover(
function() {
$(this).attr(’title’, ‘Test’);
},
function() {
$(this).attr(’title’, ‘OK’);
}
);


使用jQuery的好处是它包裝了各种浏览器版本对DOM对象的操作,因此统一使用$(this)而不再用this应该是比较不错的选择。


jQuery中this与$(this)的区别就介绍到这里。


### 2、典型错误与注意点



var node = KaTeX parse error: Expected 'EOF', got '#' at position 3: ('#̲id'); node.clic…(this).css();      //正确   $(this)是一个jquery对象,不是html元素,可以用css()方法
  this.style.display = ‘block’;  //正确 this是一个html元素,不是jquery对象,因此this不能调用jquery的css()方法,但是可以用javascript来更改style属性

});


**不要滥用$(this)**


如果不了解javasrcipt中基本的DOM属性和方法的话,很容易滥用jQuery对象。比如:



$(‘#someAnchor’).click(function() {

alert( $(this).attr(‘id’) );

});


如果你只是通过jQ对象获取简单的**dom元素的属性**比如id,那么你完全可以使用js原生的方法:



$(‘#someAnchor’).click(function() {

alert( this.id );

});


诸如“src,” “href,” 和“style.”等一些属性在老版本的ie中使用了getAttribute方法。




### 最后

由于篇幅限制,pdf文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!

**[开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】](https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0)**

![](https://img-blog.csdnimg.cn/img_convert/b75f5c242357ef53a3ca6a8179f17c34.webp?x-oss-process=image/format,png)

![](https://img-blog.csdnimg.cn/img_convert/cce3be5fa19afeb92e0793455534f20b.webp?x-oss-process=image/format,png)



d4c3ab8389e65ecb71ac0)**

[外链图片转存中...(img-mKhKkMeH-1715788032849)]

[外链图片转存中...(img-mlGUFeBp-1715788032849)]



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值