Як я можу використовувати JavaScript для створення та створення стилю (та додавання до сторінки) діла із вмістом? Я знаю, що це можливо, але як?
Як я можу використовувати JavaScript для створення та створення стилю (та додавання до сторінки) діла із вмістом? Я знаю, що це можливо, але як?
Відповіді:
var div = document.createElement("div");
div.style.width = "100px";
div.style.height = "100px";
div.style.background = "red";
div.style.color = "white";
div.innerHTML = "Hello";
document.getElementById("main").appendChild(div);
<body>
<div id="main"></div>
</body>
var div = document.createElement("div");
div.style.width = "100px";
div.style.height = "100px";
div.style.background = "red";
div.style.color = "white";
div.innerHTML = "Hello";
document.getElementById("main").appendChild(div);
OR
document.body.appendChild(div);
Використовуйте батьківське посилання замість document.body.
Залежить від того, як ти це робиш. Чистий javascript:
var div = document.createElement('div');
div.innerHTML = "my <b>new</b> skill - <large>DOM maniuplation!</large>";
// set style
div.style.color = 'red';
// better to use CSS though - just set class
div.setAttribute('class', 'myclass'); // and make sure myclass has some styles in css
document.body.appendChild(div);
Зробити те ж саме, використовуючи jquery, бентежно легко:
$('body')
.append('my DOM manupulation skills dont seem like a big deal when using jquery')
.css('color', 'red').addClass('myclass');
Ура!
divтому не відповідає на питання
Хоча інші відповіді тут працюють, я помічаю, що ви попросили діва із вмістом. Тож ось моя версія з додатковим вмістом. Посилання JSFiddle внизу.
JavaScript (з коментарями):
// Creating a div element
var divElement = document.createElement("Div");
divElement.id = "divID";
// Styling it
divElement.style.textAlign = "center";
divElement.style.fontWeight = "bold";
divElement.style.fontSize = "smaller";
divElement.style.paddingTop = "15px";
// Adding a paragraph to it
var paragraph = document.createElement("P");
var text = document.createTextNode("Another paragraph, yay! This one will be styled different from the rest since we styled the DIV we specifically created.");
paragraph.appendChild(text);
divElement.appendChild(paragraph);
// Adding a button, cause why not!
var button = document.createElement("Button");
var textForButton = document.createTextNode("Release the alert");
button.appendChild(textForButton);
button.addEventListener("click", function(){
alert("Hi!");
});
divElement.appendChild(button);
// Appending the div element to body
document.getElementsByTagName("body")[0].appendChild(divElement);
HTML:
<body>
<h1>Title</h1>
<p>This is a paragraph. Well, kind of.</p>
</body>
CSS:
h1 { color: #333333; font-family: 'Bitter', serif; font-size: 50px; font-weight: normal; line-height: 54px; margin: 0 0 54px; }
p { color: #333333; font-family: Georgia, serif; font-size: 18px; line-height: 28px; margin: 0 0 28px; }
Примітка: лінії CSS, запозичені у Ratal Tomal
Ось одне рішення, яке я б використав:
var div = '<div id="yourId" class="yourClass" yourAttribute="yourAttributeValue">blah</div>';
Якщо ви хотіли, щоб значення атрибутів та / або атрибутів базувалися на змінних:
var id = "hello";
var classAttr = "class";
var div = '<div id='+id+' '+classAttr+'="world" >Blah</div>';
Потім, щоб прикласти до тіла:
document.getElementsByTagName("body").innerHTML = div;
Легкий як пиріг.
[0]при використанні getElementsByTagName(). (Занадто коротке для редагування)
Ви можете створити так
board.style.cssText = "position:fixed;height:100px;width:100px;background:#ddd;"
document.getElementById("main").appendChild(board);
Повний фрагмент для запуску:
var board;
board= document.createElement("div");
board.id = "mainBoard";
board.style.cssText = "position:fixed;height:100px;width:100px;background:#ddd;"
document.getElementById("main").appendChild(board);
<body>
<div id="main"></div>
</body>
створити div з іменем id
var divCreator=function (id){
newElement=document.createElement("div");
newNode=document.body.appendChild(newElement);
newNode.setAttribute("id",id);
}
додати текст до діл
var textAdder = function(id, text) {
target = document.getElementById(id)
target.appendChild(document.createTextNode(text));
}
код тесту
divCreator("div1");
textAdder("div1", "this is paragraph 1");
вихід
this is paragraph 1
Ще одна річ, яку мені подобається робити, - це створити об'єкт, а потім перекинути його через об'єкт і встановити такі стилі, тому що це може бути стомлюючим писати кожен окремий стиль один за одним.
var bookStyles = {
color: "red",
backgroundColor: "blue",
height: "300px",
width: "200px"
};
let div = document.createElement("div");
for (let style in bookStyles) {
div.style[style] = bookStyles[style];
}
body.appendChild(div);