封装一些可能会用到的JS的Dom操作方法(非JS自带的方法)

1. 父元素节点下的子元素节点逆序

javascript 复制代码
HTMLElement.prototype.childRevers = function () {
    var all_num = this.childElementCount;

    if (all_num) {
        while(all_num--){
            this.appendChild(this.children[all_num]);
        }
    }
}
// 获取 ul 父节点对象
var oul = document.getElementsByTagName('ul')[0];
oul.childRevers();

效果:
使用前:


使用后:

2. insertAfter() 方法(相对于 insertBefore() 方法)

javascript 复制代码
Node.prototype.insertAfter = function (obj, beforEle) {
    // 判断该元素是否有下个兄弟元素
    if (beforEle.nextElementSibling) {
    	// 有的话使用 insertBefore 在下一个兄弟元素之前添加
        beforEle.parentElement.insertBefore(obj, beforEle.nextElementSibling);
    } else {
    	// 没有的话直接appendChild添加
        beforEle.parentElement.appendChild(obj);
    }
}

// 要插入的元素
var op = document.createElement('p');
// 父元素
var oul = document.getElementsByTagName('ul')[0];
// 要在插入在哪个子元素之后
var oli1 = document.getElementsByTagName('li')[1];
// 调用方法
oul.insertAfter(op, oli1);

效果:
使用前:

使用后:

3. 寻找兄弟元素节点

说明:

参数为正,找到之后的第N个

参数为负,找到之前的第N个

参数为零,找到自己

javascript 复制代码
/**
 * 寻找兄弟元素节点
 * 参数为正,找到之后的第N个
 * 参数为负,找到之前的第N个
 * 参数为零,找到自己
 */

HTMLElement.prototype.findElemSibling = function (num) {
    // num存在,但是不是number
    if (num !== undefined && typeof (num) !== "number") {
        return undefined;
    }

    var t_ele = this;
    while (num) {
        if (num > 0) {
            t_ele = t_ele.nextElementSibling;
            num--;
        } else if (num < 0) {
            t_ele = t_ele.previousElementSibling;
            num++;
        }
        if (!t_ele) {
            break;
        }
    }
    return t_ele
}

var oli = document.getElementsByTagName('li')[1];
console.log(oli.findElemSibling(-1));

效果:
使用前:


使用后:

4. 遍历一个父级元素下面的所有子元素节点

javascript 复制代码
HTMLElement.prototype.getAllChildNode = function () {
    var ele_arr = []
    if (this.childElementCount) {
        for (let i = 0; i < this.childElementCount; i++) {
            let item = this.children[i];
            ele_arr.push(item)
            if (item.childElementCount) {
                ele_arr = ele_arr.concat(item.getAllChildNode())
            }
        }
    }
    return ele_arr;
}
var odiv = document.getElementsByTagName('div')[0];
console.log(odiv.getAllChildNode());

效果:
使用前:


使用后:

5. 找出一个元素的第N层父级元素

javascript 复制代码
HTMLElement.prototype.getEleParent = function (num) {
    // num存在,但是不是number
    if (num !== undefined && typeof (num) !== "number") {
        return undefined;
    }
    var t_ele = {};
    var all_num = num;

    // 只有大于零才会查找
    if (num > 0) {
        t_ele = this;
        while (num) {
            if (t_ele.parentElement) {
                t_ele = t_ele.parentElement;
            } else {
                t_ele = null;
                break;
            }

            num--;
        }
        return t_ele;
    } else {
        return undefined;
    }
}

var oa = document.getElementsByClassName('item_a')[0];
console.log(oa.getEleParent(2))

效果:
使用前:

使用后:

相关推荐
2501_9209317026 分钟前
React Native鸿蒙跨平台采用ScrollView的horizontal属性实现横向滚动实现特色游戏轮播和分类导航
javascript·react native·react.js·游戏·ecmascript·harmonyos
身如柳絮随风扬1 小时前
Java中的CAS机制详解
java·开发语言
0思必得02 小时前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
韩立学长2 小时前
【开题答辩实录分享】以《基于Python的大学超市仓储信息管理系统的设计与实现》为例进行选题答辩实录分享
开发语言·python
东东5162 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
froginwe112 小时前
Scala 循环
开发语言
catino2 小时前
图片、文件的预览
前端·javascript
m0_706653233 小时前
C++编译期数组操作
开发语言·c++·算法
故事和你913 小时前
sdut-Java面向对象-06 继承和多态、抽象类和接口(函数题:10-18题)
java·开发语言·算法·面向对象·基础语法·继承和多态·抽象类和接口
Bruk.Liu3 小时前
(LangChain实战2):LangChain消息(message)的使用
开发语言·langchain