原生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实例的全部内容,希望能给大家一个参考。
热门推荐
如何网络匿名举报偷税漏税
食品如何出口美国?10分钟学会FDA登记认证
陆军某合成旅“杨根思连”|英雄的连队,英雄的兵
为龙猫提供一个家
2024留学生落户上海全流程,申请流程需要多长时间?
金钼集团:以“新”提质 增强高质量发展新动能
茶喝完心慌:喝了茶后心慌的原因及解决方法
南桥丨《易经》翻译史上的几个“贵人”
出口退税报关单与提单的一致性关键问题探讨
如何确定市净率的合理范围?这种确定方法对投资有何帮助?
水泡:摩擦、烫伤、破掉、变硬后的恢复时间及处理方法
PDF vs PDF/A:有什么区别?如何转换?
揭秘微积分中的“秘密武器”:拉格朗日中值定理的应用与意义
蛋鸡养殖成本及效益怎么计算?
员工离职原因有哪些常见类型?
科创板新股定价规则(科创板新股定价规则最新)
电势差公式及其推导公式(电势差的概念及计算)
SL-SLAM:精度超越ORB-SLAM3,利用深度学习进行特征点检测的鲁棒系统
蓝田规划地铁23号线!西安“县县通地铁”还有多远?
4次胃镜都是良性,为何最后确诊胃癌晚期?这种胃癌最狡猾
楼承板上混凝土厚度及钢筋选型标准详解
鸿蒙用什么开发语言
假胯宽怎么改善?运动、物理治疗和日常姿势调整全方位解析
个体能量的勇气层级是否容易达到?
健身练什么动作?新手到进阶的全面指南
2024年冷门专业有哪些 什么专业冷门但前景好
急性根尖牙周炎的应急处理措施
对决舍甫琴科后 安德拉德计划挑战努涅斯与张伟丽
运动后的选择:一杯牛奶的益处
北方蓝莓苗哪个品种好