• JS----DOM节点操作:创建 ,插入,删除,复制,查找节点


    摘自:https://blog.csdn.net/torrex/article/details/54376633

    一、创建节点、追加节点
    1、createElement(标签名)创建一个元素节点(具体的一个元素)。
    2、appendChild(节点)追加一个节点。
    3、createTextNode(节点文本内容)创建一个文本节点

    		var oDiv = document.createElement("div");//创建一个div元素,因为是document对象的方法。
    		var oDivText = document.createTextNode("666");//创建一个文本节点内容是“666”,因为是document对象的方法。
    		oDiv.appendChild(oDivText);//父级.appendChild(子节点);在div元素中添加“666”
    		document.body.appendChild(oDiv);//父级.appendChild(子节点);;document.body是指向<body>元素
    		document.documentElement.appendChild(createNode);//父级.appendChild(子节点);;document.documentElement是指向<html>元素
    

    二、插入节点
    1、appendChild(节点)也是一种插入节点的方式,还可以添加已经存在的元素,会将其元素从原来的位置移到新的位置。
    2、insertBefore(a,b)是参照节点,意思是a节点会插入b节点的前面。

    		var oDiv = document.createElement("div");//创建一个div元素,因为是document对象的方法。
    		var oDiv1 = document.getElementById("div1");
      	        document.body.insertBefore(oDiv,oDiv1);//在oDiv1节点前插入新创建的元素节点
     		ul.appendChild(ul.firstChild); //把ul的第一个元素节点移到ul子节点的末尾
    

    三、删除、移除节点
    1、removeChild(节点) 删除一个节点,用于移除删除一个参数(节点)。其返回的被移除的节点,被移除的节点仍在文档中,只是文档中已没有其位置了。

    	var removeChild = document.body.removeChild(div1);//移除document对象的方法div1
    

    四、替换节点
    1、replaceChild(插入的节点,被替换的节点) ,用于替换节点,接受两个参数,第一参数是要插入的节点,第二个是要被替换的节点。返回的是被替换的节点。

    	var replaceChild= document.body.replaceChild(div1,div2); //将div1替换div2
    

    五、查找节点
    1、childNodes 包含文本节点和元素节点的子节点。

    		for (var i = 0; i < oList.childNodes.length; i++) {//oList是做的ul的对象。
    		//nodeType是节点的类型,利用nodeType来判断节点类型,再去控制子节点
    		//nodeType==1 是元素节点
    		//nodeType==3 是文本节点
    			if (oList.childNodes[i].nodeType == 1) {//查找到oList内的元素节点
    				console.log(oList.childNodes[i]);//在控制器日志中显示找到的元素节点
    			}
    		}
    

    2、A、children也可以获取子节点,而且兼容各种浏览器。包括IE6-8
    B、parentNode:获取父节点

    		var oList = document.getElementById('list');//oList是做的ul的对象
    		var oChild=document.getElementById('child');//oChild是做的ul中的一个li的对象
    		//通过子节点查找父节点//parentNode:获取父节点
    		console.log(oChild.parentNode);//在控制器日志中显示父节点
    		console.log(oList.children);//在控制器日志中显示oList子节点
    		console.log(children.length)//子节点的个数
    

    3、A、firstChild ; firstElementChild查找第一个子节点。此存在浏览器兼容问题:firstChild是IE兼容,firstElementChild是非IE兼容。

    		//查找第一个子节点的封装函数
    		function firstChild(ele) {
    			if (ele.firstElementChild) {//如果该条件是true则在该浏览器(IE或非IE)中兼容
    				return ele.firstElementChild;
    			} else {
    				return ele.firstChild;
    			}
    		}
    		firstChild(oList).style.background = 'red';//将获得的节点的背景变成红色
    

    B、lastChild ; lastElementChild查找最后一个子节点。此存在浏览器兼容问题:lastChild 是IE兼容,lastElementChild是非IE兼容。

    		//查找最后一个子节点的封装函数
    		function lastChild(ele) {
    			if (ele.lastElementChild) {//如果该条件是true则在该浏览器(IE或非IE)中兼容
    				return ele.lastElementChild;
    			} else {
    				return ele.lastChild;
    			}
    		}
    		lastChild(oList).style.background = 'red';//将获得的节点的背景变成红色
    

    C、nextSibling ; nextElementSibling查找下一个兄弟节点。也是存在兼容性问题。

    		//查找下一个兄弟节点的封装函数
    		function nextSibling(ele) {
    			if (ele.nextElementSibling) {
    				return ele.nextElementSibling;
    			} else {
    				return ele.nextSibling;
    				}
    			}
    		nextSibling(oMid).style.background = 'red';
    

    D、previousSibling ; previousElementSibling查找上一个兄弟节点。也是存在兼容性问题。

    		//查找上一个兄弟节点的封装函数
    		function previousSibling(ele) {
    			if (ele.nextElementSibling) {
    				return ele.previousElementSibling;
    			} else {
    				return ele.previousSibling;
    					}
    			}
    		previousSibling(oMid).style.background = 'red';
    
  • 相关阅读:
    快速了解微信小程序的使用,一个根据小程序的框架开发的 todos app
    剖析简易计算器带你入门微信小程序开发
    微信第一个“小程序”亮相:不是APP胜似APP!
    hello-weapp 微信小程序最简示例教程
    微信小程序剖析【下】:运行机制
    微信小程序「官方示例代码」浅析【上】
    微信小程序开发:Flex布局
    一个HTML5老兵坦言:我们真的需要“小程序”么?
    迅雷首席架构师刘智聪:微信小程序的架构与系统设计的几点观感
    微信小程序开发:http请求
  • 原文地址:https://www.cnblogs.com/princeness/p/11664981.html
Copyright © 2020-2023  润新知