Как исправить удаление элементов в выпадающем списке (Материализация) - PullRequest
0 голосов
/ 11 января 2019

Выпадающие окна не удаляются, как ожидалось.

После миграции Materialise с версии 0.97 на 1.0.0 функция не работает. Удаляется только текст в раскрывающемся списке, а не весь элемент.

M.AutoInit();

function removeEdit() {
    var el = document.getElementById("edit");
    el.parentNode.removeChild(el);
}
<html>
<head>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/materialize/1.0.0/css/materialize.min.css">
</head>

<body>
<script src="https://cdnjs.cloudflare.com/ajax/libs/materialize/1.0.0/js/materialize.min.js"></script>
</body>
<!-- Record actions -->
  <ul id="actions" class="dropdown-content">
    <li><a href="#" id="edit" onclick="alert('edit')" class="black-text">Edit</a></li>
    <li><a href="#" id="delete" onclick="alert('delete')" class="black-text">Delete</a></li>
  </ul>

 <button type="button" onclick="removeEdit()">Remove element edit</button>
  
  <table class="bordered">
	<thead class='t-h'>
	  <tr class="tr-h" >
        <th>Column 1</th>
        <th>Column 2</th>
        <th>Column 3</th>
      </tr>
    </thead>
    <tbody class='t-body'>
      <tr id="1" class="tr-d dropdown-trigger" href="#" hover="false" data-target="actions">
	    <td>Row 1, column 1</td>
	    <td>Row 1, column 2</td>
	    <td>Row 1, column 3</td>
      </tr>
      <tr id="2" class="tr-d dropdown-trigger" href="#" hover="false" data-target="actions">
        <td>Row 2, column 1</td>
        <td>Row 2, column 2</td>
        <td>Row 2, column 3</td>
      </tr>
    </tbody>
  </table>
</html>

1 Ответ

0 голосов
/ 11 января 2019

В функции removeEdit, el представляет выбранное <a>, поэтому el.parentNode представляет выбранное <li>.

Когда вы используете el.parentNode.removeChild(el), это означает, что удалить дочерний элемент для выбранного <li>, поэтому он удаляет тег <a>.

Изменение:

el.parentNode.removeChild(el);

Кому:

el.parentNode.remove();

И удаляет выделенные <li>.

...