이 글은 주로 JS에서 노드를 얻는 방법과 호환성 캡슐화를 소개합니다. 도움이 필요한 친구들에게 도움이 되길 바랍니다!
웹 페이지의 콘텐츠는 태그로 구성됩니다(완전히 정확하지는 않음)
웹 페이지의 콘텐츠는 노드로 구성됩니다.
Element 노드 Attribute 노드 Text 노드 Comment 노드 Document 노드
node의 세 가지 요소
节点类型(nodeType) 节点名称( nodeName) 节点值(nodeValue) 元素节点 1 标签名大写 null属性节点 2 属性名 属性值 文本节点 3 #text 文本 注释节点 8 #comment 注释内容 文档节点 9 #document null
부모 노드 가져오기:child element.parentNode
자식 요소 가져오기
千与千寻哈儿的移动城堡龙猫悬崖上的金鱼姬
var box2 = document.getElementById("box2");console.log(box2.parentNode);
얻은 부모 노드는 요소여야 합니다. 노드(요소만 하위 노드가 있음)
페이지에 하위 요소 추가(상위 요소)Parent element.appendChild(하위 요소)
千与千寻哈尔的移动城堡
千与千寻哈儿的移动城堡龙猫悬崖上的金鱼姬
var box = document.getElementById("box");var box2 = document.getElementById("box2");
console.log(box2.previousSibling); // 文本节点
next node
console.log(box2.nextSibling); // 文本节点
console.log(box2.previousElementSibling);
console.log(box2.nextElementSibling);
ie8은 형제 요소를 얻는 것의 작동을 지원하지 않습니다. , 결과는 정의되지 않았으며 IE8에는 대안이 없습니다
IE8은 노드를 통해 형제 요소 인텔리전스를 얻으려고 합니다 이전 형제 요소의 패키지 가져오기 @param ele: 찾아야 할 대상 패키지@return 노드: 요소 노드를 반환합니다
function getPreviousElement(ele) { // 能力检测 if(ele.previousElementSibling) { // 谷歌火狐 return ele.previousElementSibling; } else { // IE8 // 获取上一个节点 : null 元素 文本 注释 var node = ele.previousSibling; // 循环次数不确定 // 1. node必须存在, 不是null, 2. node不是元素节点 while(node != null && node.nodeType != 1) { node = node.previousSibling } // node == null 或者 node.nodeType == 1 return node; } } console.log(getPreviousElement(li2));
2. 첫 번째 하위 노드와 하위 요소를 가져옵니다.
parent element.firstChild
var box = document.getElementById("box");console.log(box.firstChild);console.log(box.firstElementChild);
첫 번째 하위 요소의 호환성 패키지 가져오기
function getFirstElementChild(ele) { if (ele.firstElementChild != undefined) { return ele.firstElementChild; } else { var nodeFirst = ele.firstChild; while (nodeFirst && nodeFirst.nodeType == 1) { nodeFirst = nodeFirst.nextSibling; } return nodeFirst; } } console.log(ul.firstElementChild);
마지막 하위 노드 가져오기:
Parent element.lastChild 마지막 하위 요소 가져오기:var box = document.getElementById("box");console.log(box.lastChild);console.log(box.lastElementChild);
function firstElement(ele) { if (ele.firstElementChild) {//谷歌和火狐 return ele.firstElementChild; } else {//IE8 var node = ele.firstChild; while (node != null && node.nodeType != 1) { node = node.nextSibling; } return node; } } console.log(firstElement(ul))
매개변수가 true인 경우 심층 복제를 의미합니다. 이 태그와 태그에 포함된 모든 콘텐츠를 복제할 수 있습니다.
매개변수가 false이면 얕은 복제를 의미합니다. 현재 태그만 복제할 수 있으며 이 태그의 콘텐츠는 복제되지 않습니다.
매개변수가 없습니다. 기본값은 false입니다.
I'm a big box我是标题
var box = document.getElementById("box");var Newbox = box.cloneNode(true)console.log(New);
복제된 노드는 메모리에 있는 복사본 하나만 복제하며 페이지에 추가되지 않습니다. 수동으로만 추가할 수 있습니다.
복제된 huibaid도 복제됩니다
페이지 ID의 복제본을 수정해야 합니다. 요소 ID
Newbox.id = "Newbox"
관련 권장 사항: [
JavaScript 비디오 튜토리얼]위 내용은 JS를 구문 분석하여 노드를 얻고 호환성을 위해 캡슐화하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!