다음 HTML이 있다고 상상해보십시오.
<div><span><b>This is in bold</b></span></div>
div 자체를 포함하여 div에 대한 HTML을 얻고 싶습니다. Element.innerHTML은 다음 만 반환합니다.
<span>...</span>
어떤 아이디어? 감사
답변
jldupont의 답변을 확장하면 즉시 래핑 요소를 만들 수 있습니다.
var target = document.getElementById('myElement');
var wrap = document.createElement('div');
wrap.appendChild(target.cloneNode(true));
alert(wrap.innerHTML);
실제 문서에서 요소를 제거하고 다시 삽입 할 필요가 없도록 요소를 복제하고 있습니다. 그러나 인쇄하려는 요소의 아래에 매우 큰 트리가있는 경우 비용이 많이들 수 있습니다.
답변
사용 outerHTML
:
var el = document.getElementById( 'foo' );
alert( el.outerHTML );
답변
먼저 div
문제 의을 감싸는 요소를 놓고 요소 에 id
속성을 넣은 다음 그 요소에 사용 getElementById
합니다. 일단 당신이 HTML을 검색하기 위해 ‘e.innerHTML’을하세요.
<div><span><b>This is in bold</b></span></div>
=>
<div id="wrap"><div><span><b>This is in bold</b></span></div></div>
그리고:
var e=document.getElementById("wrap");
var content=e.innerHTML;
참고outerHTML
크로스 브라우저 호환되지 않습니다.
답변
더 가벼운 풋 프린트를 원하지만 더 긴 스크립트를 원한다면 innerHTML 요소를 가져 와서 빈 부모 만 만들고 복제하십시오.
function getHTML(who,lines){
if(!who || !who.tagName) return '';
var txt, ax, str, el= document.createElement('div');
el.appendChild(who.cloneNode(false));
txt= el.innerHTML;
ax= txt.indexOf('>')+1;
str= txt.substring(0, ax)+who.innerHTML+ txt.substring(ax);
el= null;
return lines? str.replace(/> *</g,'>\n<'): str;
//easier to read if elements are separated
}
답변
var x = $('#container').get(0).outerHTML;
답변
outerHTML은 IE 전용이므로 다음 함수를 사용하십시오.
function getOuterHtml(node) {
var parent = node.parentNode;
var element = document.createElement(parent.tagName);
element.appendChild(node);
var html = element.innerHTML;
parent.appendChild(node);
return html;
}
부모 유형의 가짜 빈 요소를 만들고 그것에 innerHTML을 사용한 다음 요소를 다시 일반 dom에 다시 연결합니다.
답변
크로스 브라우저가 되려면 이와 같은 것을 원할 것입니다.
function OuterHTML(element) {
var container = document.createElement("div");
container.appendChild(element.cloneNode(true));
return container.innerHTML;
}