• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Dynamiczne tworzenie elementów za pomocą Javascriptu

Object Storage Arubacloud
0 głosów
1,270 wizyt
pytanie zadane 27 czerwca 2017 w JavaScript przez nitrio578 Początkujący (270 p.)

Chciałbym przerobić poniższy kod html, na tworzony dynamicznie w js.

 <div class="row remove"> 
  <div class="col-lg-3"> 
    <div class="input-group"> 
      <span class="input-group-addon"> 
        <input class="checkbox" type="checkbox" aria-label="...">
      </span>' +
      <input type="text back" class="form-control check" aria-label="..." value = "' + add() +'">
    </div> 

  </div>
  
</div>   <li style = "justify-content: space-between;">  </li>;

Zrobiłem coś takiego tylko że elementy nie tworzą się takie jak powinny, pewnie przez że nie wiem jak pozamykać poszczególne fragmenty w odpowiednich divach.

const create =  function()  {

const div = document.createElement('div');
    div.classList.add('row');
    box.appendChild(div);
    const div2 = document.createElement('div');
    div2.classList.add('col-lg-3');
    div.appendChild(div2);
    const div3 = document.createElement('div');
     div3.classList.add('nput-group');
    div2.appendChild(div3);
    const span = document.createElement('span');
    span.classList.add('input-group-addon');
    div3.appendChild(span);
    const input = document.createElement('input');
    input.classList.add('checkbox');
    input.type = "checkbox";
    const input2 =document.createElement('input');
    input2.classList.add('form-control check');
    input2.type = "text";
    input.value = add();
    div3.appendChild(input2);
    const list = document.createElement('li');
    list.style = "justify-content: space-between;";
    box.appendChild(list);
}

 

komentarz 27 czerwca 2017 przez Tomek Sochacki Ekspert (227,510 p.)
Poczytaj o createDocumentFragment żeby co chwilę nie aktualizować DOM. Pytanie tylko po co chcesz taki kod tworzyć dynamicznie? CSS rozumiem, że i tak od razy podajesz użytkownikowi wraz ze stroną, więc te kilkadziesiąt znaczków więcej nie zrobi mu różnicy i myślę, że lepiej je również podać i po prostu dać na display:none i w razie potrzeby włączyć display:block czy inną wartość w zależności od potrzeb i JS potrzebowałyś tyko do zmiany właściwości display.
komentarz 27 czerwca 2017 przez nitrio578 Początkujący (270 p.)

To jest fragment większego kodu, który tworzę listę ToDo, po wczytaniu strony pojawia się pole tekstowe i przyciski Dodaj i Usuń, a ten kod miał tworzyć listę pól z zadaniami, które wpisał użytkownik. Najpierw zrobiłem tak

    const create =  function() {
 return '<div class="row remove">' +
  '<div class="col-lg-3">' +
    '<div class="input-group">' +
      '<span class="input-group-addon">'  +
        '<input class="checkbox" type="checkbox" aria-label="...">' +
      '</span>' +
      '<input type="text back" class="form-control check" aria-label="..." value = "' + add() +'">' +
    '</div>' +

  ' </div>' +
  
'</div>'  + '<li style = "justify-content: space-between;">  </li>';
}

i to działało tylko był problem żeby usnąć zadanie, bo usuwał się najwcześniej stworzony element, a nie ten co został wybrany do usunięcia

komentarz 27 czerwca 2017 przez xmentor Nałogowiec (49,520 p.)
Do usuwania zastosuj event delegation - najlepsze rozwiązanie.

No i https://developer.mozilla.org/pl/docs/Web/JavaScript/Referencje/template_strings
komentarz 27 czerwca 2017 przez nitrio578 Początkujący (270 p.)

Robiłem tym event delegation tylko, że też nie usuwa tego co wybiorę, nie wiem jak zrobić żeby usunął to co wybrał tu jest cały kod

Zaloguj lub zarejestruj się, aby odpowiedzieć na to pytanie.

Podobne pytania

0 głosów
1 odpowiedź 139 wizyt
0 głosów
2 odpowiedzi 1,691 wizyt
0 głosów
2 odpowiedzi 263 wizyt

92,576 zapytań

141,426 odpowiedzi

319,650 komentarzy

61,961 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...