Нажатие ввода в форме отправляет мой вводимый текст, если я добавляю кнопку отправки, он только обновляет страницу - PullRequest
1 голос
/ 02 октября 2019

Я следую учебному пособию, и оно отлично работает, оно отправляется нажатием клавиши ввода. Каким-то образом, если я добавляю кнопку отправки, она ломается, добавляя только один элемент и заменяя последний введенный. Как заставить его работать и с кнопкой отправки, и с вводом?

Вот рабочий пример:

https://codepen.io/sergestra/pen/WNeVEVE

(Я поместил кнопку отправки в html-комментарии, раскомментируйте, чтобы увидеть мою проблему.)

const form = document.querySelector('form');
const ul = document.querySelector('ul');
const button = document.querySelector('button');
const input = document.getElementById('item');
let itemsArray = localStorage.getItem('items') ? JSON.parse(localStorage.getItem('items')) : [];

localStorage.setItem('items', JSON.stringify(itemsArray));
const data = JSON.parse(localStorage.getItem('items'));

const liMaker = (text) => {
  const li = document.createElement('li');
  li.textContent = text;
  ul.appendChild(li);
}

form.addEventListener('submit', function (e) {
  e.preventDefault();

  itemsArray.push(input.value);
  localStorage.setItem('items', JSON.stringify(itemsArray));
  liMaker(input.value);
  input.value = "";
});

data.forEach(item => {
  liMaker(item);
});

button.addEventListener('click', function () {
  localStorage.clear();
  while (ul.firstChild) {
    ul.removeChild(ul.firstChild);
  }
  itemsArray = [];
});
<!doctype html>
<html lang="en">

<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">

  <title>New Tab App</title>

  <link rel="stylesheet" href="css/primitive.css">
</head>

<body>

  <div class="small-container">
    <h1>New Tab App</h1>

    <form>
      <input id="item" type="text" placeholder="New">
      <button>save note</button>
    </form>

    <h2>Items</h2>
    <ul></ul>

    <button>Clear All</button>
  </div>

  <script src="js/scripts.js"></script>
</body>

</html>

1 Ответ

1 голос
/ 02 октября 2019

Причина вашей проблемы:

Это потому, что в вашем JavaScript есть прослушиватель событий, прикрепленный к вставленному button (а также к «кнопке сброса»),Следующая часть вызывает удаление, когда вы нажимаете на вставленный button:

  button.addEventListener('click', function () {
  localStorage.clear();
  while (ul.firstChild) {
    ul.removeChild(ul.firstChild);
  }
  itemsArray = [];
});

Способ ее решения:

Можно дать «Очистить кнопку»определенный идентификатор и ссылаться на этот идентификатор в JavaScript, чтобы прикрепить click - function (сверху) к:

Для меня работает:

HTML:

<!doctype html>
<html lang="en">

<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">

  <title>New Tab App</title>

  <link rel="stylesheet" href="css/primitive.css">
</head>

<body>

  <div class="small-container">
    <h1>New Tab App</h1>

    <form>
      <input id="item" type="text" placeholder="New">
       <button>save note</button>
    </form>

    <h2>Items</h2>
    <ul></ul>

    <button id="buttonClear">Clear All</button>
  </div>

  <script src="js/scripts.js"></script>
</body>

</html>

JavaScript:

const form = document.querySelector('form');
const ul = document.querySelector('ul');
const button = document.querySelector('button');
const input = document.getElementById('item');
let itemsArray = localStorage.getItem('items') ? JSON.parse(localStorage.getItem('items')) : [];

localStorage.setItem('items', JSON.stringify(itemsArray));
const data = JSON.parse(localStorage.getItem('items'));

const liMaker = (text) => {
  const li = document.createElement('li');
  li.textContent = text;
  ul.appendChild(li);
}

form.addEventListener('submit', function (e) {
  e.preventDefault();

  itemsArray.push(input.value);
  localStorage.setItem('items', JSON.stringify(itemsArray));
  liMaker(input.value);
  input.value = "";
});

data.forEach(item => {
  liMaker(item);
});

clearbutton = document.getElementById("buttonClear");
clearbutton.addEventListener('click', function () {
   localStorage.clear();
   while (ul.firstChild) {
    ul.removeChild(ul.firstChild);
  }
  itemsArray = [];
});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...