$( "html" ).parent()方法返回一个包含document的集合,而$( "html" ).parents()返回一个空集合 哪位大神来解释下
$( "html" ).parent()方法返回一个包含document的集合,而$( "html" ).parents()返回一个空集合 为什么会返回空集合?
$( "html" ).parent()方法返回一个包含document的集合,而$( "html" ).parents()返回一个空集合 为什么会返回空集合?
2016-08-02
我已经知道这个原因了,大家可以去看下JQ源码:
里面有这么一段:这是parents()的
if ( cur.nodeType === 1 ) { //主要看这一句,当父级对象的nodeType为1时;
matched.push( cur ); //将这个父级对象插入matched数组;matched数组初始状态是空;
}
cur = cur[dir];
}
return matched; //返回这个数组
所以$("html")的父级是document,document的nodeType是9,因此不会被放入数组;
然而parent()方法就没有这个判断,
parent: function( elem ) {
var parent = elem.parentNode;
return parent && parent.nodeType !== 11 ? parent : null; //当父元素nodeType不为11时,直接返回
},
举报