>  기사  >  웹 프론트엔드  >  HTML DOM 작업에 대한 자세한 소개

HTML DOM 작업에 대한 자세한 소개

高洛峰
高洛峰원래의
2017-03-23 09:27:211526검색

HTML DOM

웹페이지가 로드되면 브라우저는 페이지의 문서 객체 모델 (문서 객체를 생성합니다. 모델).

DOM 노드유형

문서 노드(문서, 전용)

요소 노드(div, p 등의 태그)

속성노드(class, src 등)

텍스트 노드(p, div에 삽입된 텍스트)

문서

open() 메소드는 새 문서를 열고 현재 문서의 내용을 지웁니다.

구문

document.open(mimetype,replace)


HTML DOM操作的详细介绍

설명

이 방법은 삭제됩니다. 현재 HTML 문서의 내용 외에도 write() 메서드 또는 writeln() 메서드를 사용하여 새 문서를 시작합니다.

팁 및

설명

중요: open() 메서드를 호출하여 새 문서를 열고 write() 메서드를 사용하여 문서 내용을 설정한 후 다음을 수행해야 합니다. close 메소드를 사용하는 것을 잊지 마세요. 문서를 닫고 해당 내용을 강제로 표시합니다.

참고: 스크립트 또는 이벤트 핸들러 자체도 덮어쓰기 때문에 재정의된 문서의 일부인 스크립트 또는 이벤트 핸들러에서는 이 메서드를 호출할 수 없습니다.

function createNewDoc()
{
 var newDoc = document.open("test/html","replace");
 var txt = "学习 DOM 非常有趣!";
 newDoc.write(txt);
 newDoc.close();
}<input type="button" value="打开并写入一个新文档" onclick="createNewDoc()"/>

요소를 찾는 방법

//ID가 shanghai인 요소 찾기

var shanghai= docment.getElementById('shanggai');
//이름이 있는 요소 찾기 city ​​Collection
var 도시 = docment.getElementByNames('city');
//btn btn-info 클래스를 사용하여 요소 컬렉션 찾기
var 버튼 = getElementsByClassName('btn btn-info');
//cities 객체에서 태그 이름이 li인 요소 컬렉션을 찾습니다.
var li = city.getElementsByTagName('li');

태그 콘텐츠 및 속성 변경

//获取id为"div"的元素
var node = document.getElementById('div');
//增加或改变元素属性
document.getElementById('div').setAttribute("class","window j");
//返回节点名称
var name = node.nodeName;
//返回节点类型
var type = node.nodeType;
//返回父节点
var parent = node.parentNode;
//返回子节点集合
var childs = node.childNodes;
//删除当前节点
node.parentNode.removeChild(node);
//创建节点
var div = document.createElement('DIV');
//替换节点(新的节点,被替换的节点)
node.parentNode.replaceChild(div, node);
//添加子节点
node.appendChild(div);

innerText、innerHTML、nodeValue 三者的区别

innerText: 设置或获取位于启始标签和结束标签之间的字符串

<div id="div">Hello World</div>
<input type="text" id="input" />//输出为"Hello World"var div = document.getElementById(&#39;div&#39;).innerText; 
//输出为"" var input= document.getElementById(&#39;input&#39;).innerText;

innerHTML: 设置或返回位于启始标签和结束标签之间的 HTML文本

<div id="div"><span>Hello World</span></div>//输出为"
<span>Hello World</span>"var div = document.getElementById(&#39;div&#39;).innerHTML;

nodeValue: 设置或返回属性节点和文本节点的值。

<div id="div" class="div class">
  <span id="span">Hello World</span>
</div>var div = document.getElementById(&#39;div&#39;);var span = document.getElementById(&#39;span&#39;);//输出为null,因为div属于元素节点,元素节点是没有值的console.log(div.nodeValue);  

//输出为"div class" 属性节点是有值的console.log(div.getAttributeNode(&#39;class&#39;).nodeValue);  
//输出为"div"console.log(div.getAttributeNode(&#39;id&#39;).nodeValue);  

//输出为"Hello World",span实际上有一个子节点,该节点是一个文本节点,//文本节点虽然没有标签,但它依然是一个节点console.log(span.childNodes[0].nodeValue);

위 내용은 HTML DOM 작업에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.