jQuery中this与$(this)的区别总结
这⾥就谈谈this与$(this)的区别。
1、jQuery中this与$(this)的区别
$("#textbox").hover(
function() {
this.title = "Test";
},
fucntion() {
this.title = "OK”;
}
jquery是什么选择器);
这⾥的this其实是⼀个html 元素(textbox),textbox有text属性,所以这样写是完全没有什么问题的。
但是如果将this换成(this)就不是那回事了,报Error了。this与(this)的区别在此。
\\Error Code:
$("#textbox").hover(
function() {
$(this).title = "Test";
},
function() {
$(this).title = "OK";
}
);
$()这是jQuery的⼀个函数,也是最核⼼最基本的函数
功能⼀:传⼊⼀个选择器字符串,获得这个选择器对应的dom内容,保存在[]中,也就是俗称的jQuery对象。例如
('#id')(‘.class’) $(‘tag’)
功能⼆:传⼊⼀个匿名函数,例如
$(function(){})//这个匿名函数在⽹页载⼊完成后开始执⾏
功能三:将JavaScript对象包装成为jQuery对象。例如
$(this)
$({a:1,b:2,c:3})
$(ElementById('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 = $('#id');
node.click(function(){
this.css('display','block'); //报错 this是⼀个html元素,不是jquery对象,因此this不能调⽤jquery 的css()⽅法
$(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⽅法。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论