这篇文章主要介绍了jquery源码解读之hasclass()方法,以注释形式较为详细的分析了hasclass()方法的实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
本文较为详细的分析了jquery源码解读之hasclass()方法。分享给大家供大家参考。具体分析如下:
代码如下:
jquery.fn.extend({
hasclass: function( selector ) {
//将要检查的类名selector赋值给classname, l为选择器选择的当前要检查的jquery对象数组的长度。
var classname = + selector + ,
i = 0,
l = this.length;
//循环检查每一个dom元素的类名
for ( ; i < l; i++ ) {
//this[i].nodetype === 1,判断当前dom节点的节点类型,1表示元素节点。
//this[i].classname,获取当前dom节点已经存在的类名。
//rclass = /[\t\r\n\f]/g,replace(rclass, )表示移除当前dom节点类名里的制表符,换行符,回车符等。
//indexof(classname),开始在当前dom节点的类名里检索是否有你要检查的类名classname,如果>=0,表示存在,返回true,跳出函数。
if ( this[i].nodetype === 1 && ( + this[i].classname + ).replace(rclass, ).indexof( classname ) >= 0 ) {
return true;
}
}
//循环检查完了,发现每一个dom元素里都没有找到你要检查的类名,则返回false,跳出函数。
//可见,只要你的jquery对象数组里,发现有一个dom元素的类名里包含你要查找的类名,则返回true,跳出函数。
return false;
}
});
希望本文所述对大家的jquery程序设计有所帮助。