Créez <div> et ajoutez <div> dynamiquement


128

J'essaye de créer un <div>dynamiquement, avec un ajout à l' <div>intérieur. J'ai jusqu'à présent ce qui fonctionne:

var iDiv = document.createElement('div');
iDiv.id = 'block';
iDiv.className = 'block';
document.getElementsByTagName('body')[0].appendChild(iDiv);

J'ai juste du mal à créer et à ajouter le deuxième div au premier div.

Je veux essentiellement faire cela comme le balisage final:

<div id="block" class="block">
   <div class="block-2"></div>
</div>

19
C'est une façon étrange d'obtenir l'élément du corps ... il suffit de l'utiliser document.body.
Guffa

Réponses:


234

Utilisez le même processus. Vous avez déjà la variable iDivqui fait toujours référence à l'élément d'origine que <div id='block'>vous avez créé. Il vous suffit d'en créer un autre <div>et d'appeler appendChild().

// Your existing code unmodified...
var iDiv = document.createElement('div');
iDiv.id = 'block';
iDiv.className = 'block';
document.getElementsByTagName('body')[0].appendChild(iDiv);

// Now create and append to iDiv
var innerDiv = document.createElement('div');
innerDiv.className = 'block-2';

// The variable iDiv is still good... Just append to it.
iDiv.appendChild(innerDiv);

http://jsfiddle.net/W4Sup/1/

L'ordre de création de l'événement ne doit pas nécessairement être tel que je l'ai ci-dessus. Vous pouvez alternativement ajouter le nouveau innerDivau div externe avant d'ajouter les deux au <body>.

var iDiv = document.createElement('div');
iDiv.id = 'block';
iDiv.className = 'block';

// Create the inner div before appending to the body
var innerDiv = document.createElement('div');
innerDiv.className = 'block-2';

// The variable iDiv is still good... Just append to it.
iDiv.appendChild(innerDiv);

// Then append the whole thing onto the body
document.getElementsByTagName('body')[0].appendChild(iDiv);

3
Faire un «effort supplémentaire» était la morale de l'histoire :-)!

peut également raccourcir la dernière ligne avec: document.body.appendChild (iDiv);
idan hav

8
var iDiv = document.createElement('div');

iDiv.id = 'block';
iDiv.className = 'block';
document.getElementsByTagName('body')[0].appendChild(iDiv);

var div2 = document.createElement('div');

div2.className = 'block-2';
iDiv.appendChild(div2);

vous avez à peu près copié Michael Berkowski
Oliver Bayes-Shelton

3
Je ne pense pas que j'aurais pu faire ça. Les solutions simples ont généralement une faible variance: D.
Moazzam Khan

4
var iDiv = document.createElement('div'),
    jDiv = document.createElement('div');
iDiv.id = 'block';
iDiv.className = 'block';
jDiv.className = 'block-2';
iDiv.appendChild(jDiv);
document.getElementsByTagName('body')[0].appendChild(iDiv);

3

Eh bien, je ne sais pas à quel point c'est dynamique, mais parfois cela peut vous sauver la vie de débogage:

var daString="<div id=\'block\' class=\'block\'><div class=\'block-2\'></div></div>";
var daParent=document.getElementById("the ID of whatever your parent is goes in here");
daParent.innerHTML=daString;

"Rat javascript" Si je l'ai fait correctement. Fonctionne pour moi directement lorsque le div et le contenu ne sont pas eux-mêmes dynamiques bien sûr, ou vous pouvez même manipuler la chaîne pour changer cela aussi, bien que la manipulation de la chaîne soit complexe que l'approche "element.property = bla", cela est très bienvenu flexibilité, et est un excellent outil de débogage aussi :) J'espère que cela aide.


2
var i=0,length=2;

     for(i; i<=length;i++)
 {
  $('#footer-div'+[i]).append($('<div class="ui-footer ui-bar-b ui-footer-fixed slideup" data-theme="b" data-position="fixed" data-role="footer" role="contentinfo" ><h3 class="ui-title" role="heading" aria-level="1">Advertisement </h3></div>')); 

 }

Cela aurait pu être agréable d'indiquer que vous utilisiez une bibliothèque JavaScript et que votre exemple utilise un balisage différent de celui de la question d'origine.
rob

2
window.onload = function() {
  var iDiv = document.createElement('div');
  iDiv.id = 'block';
  iDiv.className = 'block';
  document.body.appendChild(iDiv);

  var iiDiv = document.createElement('div');
  iiDiv.className = 'block-2';

  var s = document.getElementById('block');
  s.appendChild(iiDiv);
}

1
var arrayDiv = new Array();
    for(var i=0; i <= 1; i++){
        arrayDiv[i] = document.createElement('div');
        arrayDiv[i].id = 'block' + i;
        arrayDiv[i].className = 'block' + i;
    }
    document.body.appendChild(arrayDiv[0].appendChild(arrayDiv[1]));

0
var iDiv = document.createElement('div');
iDiv.id = 'block';
iDiv.className = 'block';

var iDiv2 = document.createElement('div');
iDiv2.className = "block-2";

iDiv.appendChild(iDiv2);
// Append to the document last so that the first append is more efficient.
document.body.appendChild(iDiv);

0
    while(i<10){
               $('#Postsoutput').prepend('<div id="first'+i+'">'+i+'</div>');
               /* get the dynamic Div*/
               $('#first'+i).hide(1000);
               $('#first'+i).show(1000);
                i++;
                }
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.