一聚教程网:一个值得你收藏的教程网站

最新下载

热门教程

jquery中DOM元素的prev、next和siblings例子

时间:2015-04-15 编辑:简简单单 来源:一聚教程网

jquery里我们要获取某个元素的相邻元素时,可以用到的命令有三个:

next():用来获取下一个同辈元素。
prev():用来获取上一个同辈元素。
siblings():用来获取所有的同辈元素。

这次我们来获取下元素的兄弟元素,包括前一个兄弟、后一个兄弟以及其他兄弟。为了简化操作,也考虑到日常使用,我们只取元素集合中的第一个元素的兄弟元素。

1、this访问控制

$.fn._access = function(){
 if (this.length) return callback.call(this);
 else return this;
};

只在当元素集合长度大于0的时候才执行回调,否则返回this。我们约定,下划线开始的对方法、属性为私有方法、私有属性。

2、prev,前一个兄弟
/**
 * 获取当前元素的前一个兄弟元素
 * @return new this
 * @version 1.0
 * 2013年12月29日2:06:02
 */
$.fn.prev = function() {
    return this._access(function() {
        return $(this[0].previousElementSibling);
    });
};
3、next,后一个兄弟
/**
 * 获取当前元素的后一个兄弟元素
 * @return new this
 * @version 1.0
 * 2013年12月29日2:06:02
 */
$.fn.next = function() {
    return this._access(function() {
        return $(this[0].nextElementSibling);
    });
}
4、siblings,其他兄弟
/**
 * 获取当前元素的兄弟元素集合
 * @param {String} selector 选择器,可以为空
 * @return new this
 * @version 1.0
 * 2013年12月29日2:14:20
 */
$.fn.siblings = function(selector) {
    return this._access(function() {
        var element = this[0],
            children = element.parentElement.children,
            ret = [],
            i;
        this.each.call(children, function() {
            if (!this.isEqualNode(element)) {
                if (selector) {
                    _matchesSelector(this, selector) && ret.push(this);
                } else ret.push(this);
            }
        });
        return $(ret);
    });

};

获取元素的其他兄弟元素,有2种方法:

依次获得元素的前一个兄弟元素数组,然后反转,再依次获得元素的后一个兄弟元素;
获得元素的父级的子元素,然后遍历一次,除去当前元素。
这里选择的是第2种方法,其中jquery是选择的第1种。

例子








div (doesn't match since before #prev)

span#prev

div sibling

div sibling
div niece

span sibling (not div)
div sibling


热门栏目