原生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实例的全部内容,希望能给大家一个参考。
热门推荐
45度煎三文鱼配青口炖椰菜,蓝带大厨详解做法
讨好型人格的孩子该如何引导?家长怎么办?孩子讨好型人格形成原因
讨好别人是个无底洞,讨好型人格如何走出困境?
拒绝他人,为何如此困难?——探究“讨好型人格”背后的心理原因
五铢钱:影响中国货币制度近700年的真正王者
没有车损险应该如何应对?在这种情况下如何降低车辆维修成本?
汽车故障排查指南:63个常见问题及解决方案
十二星座性格特点与恋爱观全解析
从祭拜河神到文化传承:中国神鬼文化发展史
风象星座的优点和缺点解析,社交高手但真诚有限!
风象星座的特质深度解析:性格独特,天赋异禀的星座特点揭秘
烧香祈福变生意:当传统文化遇上封建迷信
香港高端酒店业:智能化升级与绿色转型双轮驱动
芝加哥治安问题频发,留学生该如何自保?
凯斯西储大学引领教育创新潮流
优化学校管理,构建和谐师生关系
高娅:以创新实践推动校园心理健康工作
如何在学校管理中提升教师职业素养?
新华基金换帅引关注,新股东加持能否扭转颓势?
白醋洗头好处多?医生提醒这些风险,双十一选购需谨慎
醋洗头去屑有科学依据,每周1-2次效果最佳
油性发质救星?苹果醋洗头效果与风险全解析
美国暴雨致玉米大豆减产,农民泪崩
“炸弹气旋”袭击美国西北部,超50万户停电
老年人怎样才能做到口腔健康
老年牙痛怎么办?应对策略与建议
美国南部遭遇罕见暴风雪 航班停飞交通瘫痪
极地涡旋再袭美东,暴风雪背后的气候危机
绍兴大湖头遗址展:揭秘2500年前古越人的“精致”生活
冬游绍兴:仓桥直街 vs 安昌古镇,谁更值得去?