[javascript] JavaScript에서 본문 또는 문서에 div 요소 추가

순수한 JavaScript로 라이트 박스를 만들고 있습니다. 이를 위해 오버레이를 만들고 있습니다. 이 오버레이를 본문에 추가하고 싶지만 페이지의 내용을 유지하고 싶습니다. 현재 코드는 오버레이 div를 추가하지만 본문의 현재 내용도 제거합니다. div 요소를 추가하고 본문에 내용을 유지하는 방법은 무엇입니까?

var el = document.getElementById('element');
var body = document.getElementsByTagName('body');
el.innerHTML = '<p><a id="clickme" href="#">Click me</a></p>';
document.getElementById('clickme').onclick = function (e) {
    e.preventDefault();
    document.body.innerHTML = '<div style="position:absolute;width:100%;height:100%;opacity:0.3;z-index:100;background:#000;"></div>';
}



답변

이것을 시도하십시오 :-

http://jsfiddle.net/adiioo7/vmfbA/

사용하다

document.body.innerHTML += '<div style="position:absolute;width:100%;height:100%;opacity:0.3;z-index:100;background:#000;"></div>';

대신에

document.body.innerHTML = '<div style="position:absolute;width:100%;height:100%;opacity:0.3;z-index:100;background:#000;"></div>';

편집 :-
이상적으로 body.appendChild는 변경하는 대신 방법 을 사용해야 합니다innerHTML

var elem = document.createElement('div');
elem.style.cssText = 'position:absolute;width:100%;height:100%;opacity:0.3;z-index:100;background:#000';
document.body.appendChild(elem);


답변

자바 스크립트 사용

var elemDiv = document.createElement('div');
elemDiv.style.cssText = 'position:absolute;width:100%;height:100%;opacity:0.3;z-index:100;background:#000;';
document.body.appendChild(elemDiv);

jQuery 사용

$('body').append('<div style="position:absolute;width:100%;height:100%;opacity:0.3;z-index:100;background:#000;"></div>');


답변

innerHTML로 모든 것을 바꾸는 대신 다음을 시도하십시오.

document.body.appendChild(myExtraNode);


답변

모든 솔루션을 한 곳에 모아 @Peter T의 포스트를 개선합니다.

Element.insertAdjacentHTML ()

function myFunction() {
    window.document.body.insertAdjacentHTML( 'afterbegin', '<div id="myID" style="color:blue;"> With some data...</div>' );
}
function addElement(){
    var elemDiv = document.createElement('div');
    elemDiv.style.cssText = 'width:100%;height:10%;background:rgb(192,192,192);';
    elemDiv.innerHTML = 'Added element with some data';
    window.document.body.insertBefore(elemDiv, window.document.body.firstChild);
    // document.body.appendChild(elemDiv); // appends last of that element
}
function addCSS() {
    window.document.getElementsByTagName("style")[0].innerHTML += ".mycss {text-align:center}";
}

사용 XPath은 DOM 트리에서 요소의 위치를 찾을 수와 XPath_Element에 지정된 위치에 지정된 텍스트를 삽입합니다. 브라우저 콘솔에서이 코드를 사용해보십시오.

function insertHTML_ByXPath( xpath, position, newElement) {
    var element = document.evaluate(xpath, window.document, null, 9, null ).singleNodeValue;
    element.insertAdjacentHTML(position, newElement);
    element.style='border:3px solid orange';
}

var xpath_DOMElement = '//*[@id="answer-33669996"]/table/tbody/tr[1]/td[2]/div';
var childHTML = '<div id="Yash">Hi My name is <B>\"YASHWANTH\"</B></div>';
var position = 'beforeend';
insertHTML_ByXPath(xpath_DOMElement, position, childHTML);


답변

시도해보십시오

document.body.innerHTML += '<div style="position:absolute;width:100%;height:100%;opacity:0.3;z-index:100;background:#000;"></div>'


답변

다음 코드를 사용하여 divHTML 코드를 만들어 직접 body(또는 요소로) 설정할 수 있습니다 .

var divStr = '<div class="text-warning">Some html</div>';
document.getElementsByTagName('body')[0].innerHTML += divStr;


답변

현대적인 방법은 ParentNode.append()다음과 같이 사용하는 것입니다.

let element = document.createElement('div');
element.style.cssText = 'position:absolute;width:100%;height:100%;opacity:0.3;z-index:100;background:#000;';
document.body.append(element);