原生js实现针对Dom节点的CRUD操作示例
本文实例讲述了原生js实现针对Dom节点的CRUD操作。分享给大家供大家参考,具体如下:
知识点,依然会遗忘。我在思考到底是什么原因。想到研究生考试准备的那段岁月,想到知识体系的建立,知识体系分为正向知识体系和逆向知识体系;正向知识体系可以理解为教科书目录,逆向知识体系可以理解考试真题。
按照知识体系建设这个思路,追求长久的深刻的记忆。决定建立正向知识体系。本文系正向知识体系的第一篇。
原生js操作dom节点:所谓的CRUD,代表create,read,update,del;也就是创建,读取,更新和删除。dom提供了api用于创建节点常用有
var div=document.createElement("div"); var p=document.createElement("p"); div.innerHTML="这是插入内容"; var text=document.createTextNode("这是文本内容"); var img=new Image();
创建元素、文本内容和图片。创建要和插入一起使用,所以
dom1.appendChild(div); dom1.insertBefore(div,dom1.querySelector("p")); function inertAfter(newElement,targetElement){ var parent=targetElement.parentNode; if (parent.lastChild==targetElement) { parent.appendChild(newElement); }else{ parent.inertBefore(newElement,targetElement.nestSibling); } } document.getElementById('id名称').preappend(div);//直接插入到父元素第一个位置 document.getElementById('id名称').append(div);//直接插入到父元素最后位置 //还有另一个api dom1.insertAdjacentHTML("afterBegin","<h1> 在文本前容器内插入内容1</h1>"); dom1.insertAdjacentHTML("beforeEnd","<h2> 在文本后容器内插入内容2</h2>"); dom1.insertAdjacentHTML("beforeBegin","<h4> 在文本前容器外插入内容4</h1>"); dom1.insertAdjacentHTML("afterEnd","<h5> 在文本后容器外插入内容5</h2>");
读取也就是选择器的功能实现
//直接选择器 var dom1=document.getElementById("dom1"); var dom1=document.querySelector("#dom1"); var matches = document.querySelectorAll("div.note, div.alert"); var div=document.getElementsByClassName(".div"); var div=document.getElementsByTagName("div"); //节点关系选择器 var divC=div.innerHTML;//内部 var divC=div.outerHTML;//整个节点 var divS=div.children;//子节点集合 var divS=div.firstChild;//第一个子节点,如果有空格返回#text var divS=div.lastChild;//最后一个子节点,如果有空格返回#text var divS=div.nextSibling;//下一个节点,如果有空格返回#text var divS=div.prvSibling;//前一个节点,如果有空格返回#text var divS=div.parentNode;//父节点 //节点集合 var form=document.forms[0];//表单集合 var img=document.images[0];//图片集合 var img=document.links[0];//所有带连接的a节点
然后是更新,我理解的是替换,常用实现
parent.replaceChild(div,dom1.querySelector("p")); dom1.innerHTML="hhh"; dom1.innerText="999";
最后是删除的实现
parent.removeChild(dom1.querySelector("p")); dom1.innerHTML=""; dom1.innerText="";
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript操作DOM技巧总结》、《JavaScript页面元素操作技巧总结》、《JavaScript事件相关操作与技巧大全》、《JavaScript查找算法技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript错误与调试技巧总结》
希望本文所述对大家JavaScript程序设计有所帮助。
相关文章
小程序按钮避免多次调用接口和点击方案实现(不用showLoading)
这篇文章主要介绍了小程序按钮避免多次调用接口和点击方案实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-04-04跟我学Node.js(四)---Node.js的模块载入方式与机制
Node.js中模块可以通过文件路径或名字获取模块的引用。模块的引用会映射到一个js文件路径,除非它是一个Node内置模块。Node的内置模块公开了一些常用的API给开发者,并且它们在Node进程开始的时候就预加载了。2014-06-06BOM系列第一篇之定时器setTimeout和setInterval
这篇文章主要介绍了BOM系列第一篇之定时器setTimeout和setInterval 的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下2016-08-08JavaScript知识点总结(十六)之Javascript闭包(Closure)代码详解
闭包是可以包含自由(未绑定)变量的代码块;这些变量不是在这个代码块或者任何全局上下文中定义的,而是在定义代码块的环境中定义。本文主要介绍了javascript中的闭包,感兴趣的朋友一起看看吧2016-05-05JavaScript代码压缩工具UglifyJS和Google Closure Compiler的基本用法
网上搜索了,目前主流的Js代码压缩工具主要有Uglify、YUI Compressor、Google Closure Compiler,简单试用了UglifyJS 和Google Closure Compiler 两种工具的基本用法,需要的朋友可以参考下2020-04-04
最新评论