原生JS实现几个常用DOM操作API实例
创作时间:
作者:
@小白创作中心
原生JS实现几个常用DOM操作API实例
引用
1
来源
1.
http://www.cdweb.net/article/psdpio.html
本文将介绍如何使用原生JavaScript实现一些常用的DOM操作API实例,包括类似jQuery的sibling方法、class选择器,以及一些常用的DOM操作函数如getElementsByClassName、addLoadEvent、addClass、insertAfter和getNextElement等。
原生实现jQuery的sibling方法
原生实现jQuery的class选择器
// 用数组模拟jQuery的class选择器
function getClassName(ParentId, NewClassName) {
var AllClassElem = ParentId.getElementsByTagName("*");
var AllClass = [];
var i = 0;
for (i = 0; i < AllClassElem.length; i++) {
if (AllClassElem[i].className == NewClassName) {
AllClass.push(AllClassElem[i]);
}
}
return AllClass;
}
// 用法:
var PElementId = document.getElementById("bar");
var buttons = getClassName(PElementId, "sco");
// 取id="bar"下class="sco"的元素;
getElementsByClassName()
/**
* 获取指定类名的元素对象集合
* @param {Object} node 父节点
* @param {String} classname 指定类名
* @return {[Object]}目标对象集合
*/
function getElementsByClassName(node, classname) {
// 如果浏览器支持则直接使用
if (node.getElementsByClassName) {
return node.getElementsByClassName(classname);
} else {
return (function getElementsByClass(searchClass, node) {
if (node == null) {
node = document;
}
var classElements = [];
var els = node.getElementsByTagName("*");
var elsLen = els.length;
var pattern = new RegExp("(^|\\s)" + searchClass + "(\\s|$)");
var i, j;
for (i = 0, j = 0; i < elsLen; i++) {
if (pattern.test(els[i].className)) {
classElements[j] = els[i];
j++;
}
}
return classElements;
})(classname, node);
}
}
addLoadEvent()
/**
* 方便的将在文档加载后运行的函数添加到window.onload中
* @param {function} func 待运行函数
*/
function addLoadEvent(func) {
var oldOnload = window.onload;
// typeof 返回String类型
if (typeof window.onload != 'function') {
window.onload = func;
} else {
window.onload = function () {
oldOnload();
func();
}
}
}
addClass()
/**
* 为指定元素结点添加新类名
* element 元素结点
* value 类名
*/
function addClass(element, value) {
// 如果元素类名为空,直接将value赋值给相应的元素类名
if (!element.className) {
element.className = value;
} else {
// 否则需要将类名之间用空格隔开
newClassName = element.className;
// 多个类名间添加空格
newClassName += ' ';
newClassName += value;
element.className = newClassName;
}
}
insertAfter()
/**
* 在目标元素结点后面插入新的元素结点
* newElement 待插入的新元素结点
* targetElement 目标元素结点
*/
function insertAfter(newElement, targetElement) {
var parent = targetElement.parentNode;
if (parent.lastChild == targetElement) {
parent.appendChild(newElement);
} else {
parent.insertBefore(newElement, targetElement.nextSibling);
}
}
getNextElement()
/**
* 获取下一个元素结点
* @param {Object} node 兄结点
* @return {Object || null}下一个元素结点或未获取到
*/
function getNextElement(node) {
var sibNode = node.nextSibling;
if (sibNode.nodeType == 1) {
return node;
}
if (sibNode.nextSibling) {
// 递归调用
return getNextElement(node.nextSibling);
}
return null;
}
以上就是使用原生JavaScript实现几个常用DOM操作API实例的全部内容,希望能给大家一个参考。
热门推荐
金融借款合同怎么写好用:核心条款与撰写技巧深度解析
交接仪式怎么策划才能顺利进行?
生活篇章:情商的重要性
要凉爽也要顾荷包!空调省电保养秘诀6+3,冻涨夏季电费
《星际公民》定下了发售日,反倒让十年老粉们动摇了
画饼十三年的《星际公民》,终于想起做游戏还得修Bug了 希望还来得及。
歼-35 vs F-35:谁能笑到最后?
彻底卸载电脑中的VMware虚拟机:五步清理指南
房地产行业全面深入分析报告
如何使用云盘实现电脑文件同步,提高工作效率?
原神卡组编辑全攻略:从入门到精通
医生解答:科学运动助力减肥的五大策略
怎么钓鲤鱼最快?掌握这7点,轻松钓获大鲤鱼
空气质量预测 - 通过气象和污染源数据预测空气质量变化
护腰会影响腰部力量吗
跨越10万年,他们用“指纹”解锁中国水稻演化史
选择不同年龄段儿童的益智玩具指南:全面提升智力与创造力的秘诀
拍视频怎么选择快门速度?为什么快门速度是帧速率的2倍?
公司制度迟到罚款的法律后果及应对策略
激光表面处理如何提升铝合金粘接性能?最新研究揭示关键机制
早产儿主要护理措施
权利与权力:法治视域下的边界划分与制衡关系
1931年九一八事变背后,东北军的真实战斗力如何?
如何规避AI写作的特征?6点方法让文章质量与真实性提升
岳飞的家族传承:英雄后代的隐秘与流散
金牛座有多深情?揭開金牛座的戀愛心理與深厚情感
彩钢板防火等级全解析:从材料选择到安装规范
大葱还是小葱?教你如何选择合适的葱丝
附子理中丸与桂附地黄丸的同服奥秘
2024年中国出口创新高:东南亚贡献最大,对美出口改善最多