操作DOM

操作DOM
	DOM是什么
        DOM:是树状的html
		document:是DOM的根节点     
		HTML文档被浏览器解析后就是一棵DOM树,要改变HTML的结构,可以通过JavaScript来操作DOM。
    始终记住DOM是一个树形结构。
 	
	对DOM操作
		操作一个DOM节点实际上就是这么几个操作:
		更新:更新该DOM节点的内容,相当于更新了该DOM节点表示的HTML的内容;
		遍历:遍历该DOM节点下的子节点,以便进行进一步操作;
		添加:在该DOM节点下新增一个子节点,相当于动态增加了一个HTML节点;
		删除:将该节点从HTML中删除,相当于删掉了该DOM节点的内容以及它包含的所有子节点。

查找节点
		document.getElementById()//返回
		document.getElementsByTagName()
		document.getElementsByClassName()
        document.querySelector();
		document.querySelectorAll()
   
		//根据id找元素
		var test = document.getElementById('test')
		var trs = document.getElementById('test-table').getElementsByTagName('tr');
		// 获取节点test下的所有直属子节点:
		var cs = test.children;
		// 获取节点test下第一个、最后一个子节点:
		var first = test.firstElementChild;
		var last = test.lastElementChild;
		

		// 通过querySelector获取ID为q1的节点:
		var q1 = document.querySelector('#q1');
		// 通过querySelectorAll获取q1节点内的符合条件的所有节点:
		var ps = q1.querySelectorAll('div.highlighted > p');
			
更新DOM
	更新DOM元素的内容
		一种是修改innerHTML属性,这个方式非常强大,不但可以修改一个DOM节点的文本内容,还可以直接通过HTML片段修改DOM节点内部的子树:
			var p = document.getElementById('p-id');
			//更新文本
			p.innerHTML = 'ABC'; // <p id="p-id">ABC</p>
			//修改HTML的结构
			p.innerHTML = 'ABC <span style="color:red">RED</span> XYZ';
			// <p>...</p>的内部结构已修改
			用innerHTML时要注意,是否需要写入HTML。如果写入的字符串是通过网络拿到了,要注意对字符编码来避免XSS攻击
		第二种是修改innerText或textContent属性,这样可以自动对字符串进行HTML编码,保证无法设置任何HTML标签:
			var p = document.getElementById('p-id');
			p.innerText = '<script>alert("Hi")</script>';
			两者的区别在于读取属性时,innerText不返回隐藏元素的文本,而textContent返回所有文本。另外注意IE<9不支持textContent。
		

插入DOM
	如果这个DOM节点是空的,例如,<div></div>,那么,直接使用innerHTML = '<span>child</span>'就可以修改DOM节点的内容,相当于“插入”了新的DOM节点	
	有两个办法可以插入新的节点。
	  方法1:使用appendChild,把一个子节点添加到父节点的最后一个子节点
		js = document.getElementById('js'),
		list = document.getElementById('list');
		list.appendChild(js);
		更多的时候我们会从零创建一个新的节点,然后插入到指定位置
			var d = document.createElement('style');
			d.setAttribute('type', 'text/css');
			d.innerHTML = 'p { color: red }';
			document.getElementsByTagName('head')[0].appendChild(d);
			
	insertBefore
		如果我们要把子节点插入到指定的位置怎么办?
			可以使用parentElement.insertBefore(newElement, referenceElement);
				子节点会插入到referenceElement之前
		
删除DOM
	父元素删除
		这是常用的解决方案:找到您希望删除的子元素,然后使用其 parentNode 属性来找到父元素:
		var child=document.getElementById("p1");
		child.parentNode.removeChild(child);	
	自己删掉
		// 拿到待删除节点:
		var self = document.getElementById('to-be-removed');
		// 拿到父节点:
		var parent = self.parentElement;
		// 删除:
		var removed = parent.removeChild(self);
 		self.remove();
		removed === self; // true
		注意到删除后的节点虽然不在文档树中了,但其实它还在内存中,可以随时再次被添加到别的位置。
		因此,删除多个节点时,要注意children属性时刻都在变化

复制节点
	var self = document.getElementById('to-be-removed');
	self .cloneNode(true);

修改节点属性7
	节点对象.属性,只能访问节点固有的属性,访问不到自定义的属性
	节点对象.getAttribute()能访问所有的属性,以后常用
		div.getAttribute('msg')
	节点对象.setAttribute()
		div.setAttribute("class","zhangss12112312312");
	节点对象.removeAttribute()
		div.removeAttribute("class");

DOM 定义了访问和操作 HTML 文档的标准
	在 HTML DOM 中,所有事物都是节点。
	
	HTML 文档中的所有内容都是节点:
		文档节点:整个文档
		元素节点:每个 HTML 元素
		文本节点:HTML 元素内的文本
		属性节点:每个 HTML 属性
		注释是注释节点
		
	节点树中的节点彼此拥有层级关系
		父(parent)、子(child)和同胞(sibling)
	document就是html节点
	为什么节点的第一个子节点不是属性节点而是文本节点
		因为:属性节点藏在元素节点里面,所以你不能通过正常的方式获得到属性节点
	索引就是下标,只是叫法不一样

	parentNode,parentElement,childNodes,children区别
	childNodes包含文本节点和元素节点
	children仅包含元素节点
	parentNode、parentElement是一样的

				
修改CSS		
		DOM节点的style属性对应所有的CSS,可以直接获取或设置。
		因为CSS允许font-size这样的名称,但它并非JavaScript有效的属性名,所以需要在JavaScript中改写为驼峰式命名fontSize:
			var p = document.getElementById('p-id');
			// 设置CSS:
			p.style.color = '#ff0000';
			p.style.fontSize = '20px';
			p.style.paddingTop = '2em';				
				
				
				
				
				
				
				
  

  


posted on 2019-06-10 17:06  悬剑  阅读(174)  评论(0编辑  收藏  举报

导航