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

JavaScript - ukryty event blur? Jak go usunąć?

VPS Starter Arubacloud
0 głosów
397 wizyt
pytanie zadane 2 września 2019 w JavaScript przez dabgan Początkujący (410 p.)

Witam! Tworzę To-Do listę i próbowałem nadać itemom z listy taką funkcjonalność, że po doubleclicku można je edytować. Po czym po wciśnięciu entera lub straceniu przez item focusu zmiany mają się zapisywać. 

Wszystko działa tak jak powinno, jednakże w consoli pokazuje mi błąd. Próbując znaleźć coś w google, dowiedziałem się że chyba chodzi o ukryte wydarzenie onblur które odbywa się podczas usuwania elementu, ale nie potrafię tego jednak jakoś rozgryźć, zrozumieć? Wrzucam kawałek kodu: 

    // target items created dynamically and add editability to items
    ul.addEventListener('dblclick', (event) => {
      const clickedItem = event.target;
      const clickedElementJob = clickedItem.dataset.job;
      const value = clickedItem.textContent;
      if (clickedElementJob == 'edit'){
       clickedItem.outerHTML =  `<input class="text " data-job="edit" value='${value}'></input>`;
      }
    });

    // target items created dynamically and check if they are input fields, if so get the value when enter pressed
    ul.addEventListener('keypress', function pressEnter(event){
      if (event.keyCode == 13){
        saveChanges(event);
      }
    });

    // target items created dynamically and check if they are input fields, if so get the value when loose focus
    ul.addEventListener('focusout', function looseFocus(event){
      saveChanges(event);
    });


    function saveChanges(event){
      const clickedItem = event.target;
      if (clickedItem.hasAttribute('value')){
          const newInput = document.querySelector('[value]');
          const listItem = list[clickedItem.previousElementSibling.id];
          clickedItem.outerHTML =  `<p class="text " data-job="edit">${newInput.value}</p>`;
          listItem.name = newInput.value;
      }
      localStorage.setItem('items', JSON.stringify(list));
    };

 

komentarz 2 września 2019 przez BT101 Stary wyjadacz (12,540 p.)
Wstaw kod na codepen i treść błędu
komentarz 3 września 2019 przez dabgan Początkujący (410 p.)

@BT101 Treść błędu to: 

newScript.js:162 Uncaught DOMException: Failed to set the 'outerHTML' property on 'Element': The node to be removed is no longer a child of this node. Perhaps it was moved in a 'blur' event handler?
    at saveChanges (file:///C:/Users/Praca/Desktop/Coding/Projects/Project%2001%20-%20ToDo%20List/js/newScript.js:162:33)
    at HTMLUListElement.pressEnter (file:///C:/Users/Praca/Desktop/Coding/Projects/Project%2001%20-%20ToDo%20List/js/newScript.js:145:9)

natomiast tutaj na codepen wklejam cały kod: https://codepen.io/dabgan/pen/JjPrqbx

komentarz 3 września 2019 przez BT101 Stary wyjadacz (12,540 p.)
Postaraj się z tego wyszczególnić kod powodujący błąd, stwórz minimalną reprodukcje błędu bez całej otoczki, nikt nie będzie debugował 200 linii skryptu.

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

Podobne pytania

0 głosów
0 odpowiedzi 306 wizyt
pytanie zadane 12 listopada 2018 w JavaScript przez ajzyn Użytkownik (510 p.)
0 głosów
2 odpowiedzi 469 wizyt
0 głosów
1 odpowiedź 459 wizyt

92,453 zapytań

141,262 odpowiedzi

319,088 komentarzy

61,854 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

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 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!

...