原生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实例的全部内容,希望能给大家一个参考。
热门推荐
前胸后背长痘痘怎么办?中医专家教你轻松应对
鱼油对眼睛的功效与作用
甲状腺显像的临床意义是什么
西藏羊卓雍措:高原明珠的神秘与美丽
李白《蜀道难》创新之处解读
40句诗意伤感句子:从古至今的情感共鸣
能力致胜:破解职场困局的“四力”之道
如何有效查看和优化电脑显存使用情况的实用指南
项目验收后怎么管理业务
小型汽油机保养内容有哪些?这些要点要注意
春游活动指南:踏青赏花、野餐烧烤、团队游戏……玩转春天!
如何高效进行热点事件舆情分析?揭秘实战攻略与技巧
家政服务中的法律关系辨析:公司、员工与雇主之间的权利义务
深度:湖人一路攀升到西部第二,一定程度上他的贡献大过东契奇和詹姆斯
厕所门对窗户好吗?家居风水禁忌解析
胶原蛋白肽分子量,胶原蛋白肽的作用与功效
测试人员如何转项目管理
浅析朱自清《春》的艺术特色
全屋踢脚线哪种材质最好?4种材质全面对比,三种方案供你选择!
断桥铝门窗有哪些型材规格?怎么选?
云服务器怎么赚钱?12种模式让服务器创造收入
从央行资产负债表看货币政策工具变迁—写在央行借入卖出国债之际
2024年去眼袋手术须知:术后注意事项全面介绍
降低成本、缓缴关税 内江保税物流中心封关为企业带来多重利好
"中企出海越南,发现成本没那么低"
央视主持毕福剑:从舞台中心到公益路上的暖心大叔
救命知识!运动性晕厥这样急救
波浪形容什么?波浪理论在投资中有哪些应用?
当法语与中国民谣契合,安娜和她的朋友们边走边唱
牙根发炎导致牙痛?4个常见原因、症状和治疗方式