Выбор конкретной вновь добавленной копии узла для события jQuery - PullRequest
0 голосов
/ 08 июня 2018

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

$(document).ready(function() {
  $(".test2").click(function() {
    $("#samplesinfo").clone(true).insertAfter("#paste");
  });
  $(".accordion").click(function() {
    $(".panel").toggle();
  });
  $(".delbtn").click(function() {
    $("#samplesinfo").remove();
  });
});
.accordion {
  background-color: #eee;
  color: #444;
  cursor: pointer;
  padding: 18px;
  width: 100%;
  border: none;
  text-align: left;
  outline: none;
  font-size: 15px;
  transition: 0.4s;
}

.active,
.accordion:hover {
  background-color: #ccc;
}

.panel {
  padding: 0 18px;
  display: none;
  background-color: white;
  overflow: hidden;
}

.close {
  float: right;
  padding: 12px 16px 12px 16px;
}

.close:hover {
  background-color: #f44336;
  color: white;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">

<h2>Example</h2>
<button class="test2">ADD</button>

<div id="samplesinfo">
  <div class="test">
    <button class="delbtn" id="delbtn" style="float: right;">Delete</button>
    <button id="sample" class="accordion" style="float: left;">Button</button>
    <div id="usrInput" class="panel">
      <input type="text" name="test">
    </div>
  </div>
</div>
<div id="paste">
</div>

Кроме того, каждая кнопка содержит опцию пользовательского ввода.Удаление div должно быть сделано с определенным пользовательским вводом, который больше не нужен.Например, если вы вводите «hello» в третий скопированный элемент и нажимаете кнопку «Удалить», он должен удалять только элемент с надписью «hello», а не сверху.

Ответы [ 2 ]

0 голосов
/ 08 июня 2018

В другом ответе, когда вы «Добавить», он копирует первый, включая контент input, если вы его набрали.

Мне часто нравится использовать скрытые шаблоны, поэтому вот чтоЯ предлагаю вам:

  • Начните только с одного элемента с class="hidden".Это «шаблон».
  • Когда вы нажимаете Добавить , «шаблон» будет скопирован, сделан видимым и добавлен после вашего последнего элемента.
  • При загрузкемы запускаем событие click для запуска с одним видимым элементом.
  • Поскольку вам следует избегать встроенного моделирования, я также перенес это в CSS.

Рабочий фрагмент:

var index = 0;
$(".test2").click(function() {
  var element = $(".samplesinfo.hidden").clone(true);
  element.removeClass('hidden').insertAfter(".samplesinfo:last");
  element.find('.delbtn').text('Delete ' + ++index);
});

$(".accordion").click(function() {
  $(this).next(".panel").toggle();
});

$(".delbtn").click(function() {
  $(this).closest(".samplesinfo").remove();
});

// Trigger click on load
$(".test2").trigger('click');
.hidden{
  display: none;
}

.accordion {
  background-color: #eee;
  color: #444;
  cursor: pointer;
  padding: 18px;
  width: 100%;
  border: none;
  text-align: left;
  outline: none;
  font-size: 15px;
  transition: 0.4s;
  float: left;
}

.delbtn {
  float: right;
}

.active,
.accordion:hover {
  background-color: #ccc;
}

.panel {
  padding: 0 18px;
  display: none;
  background-color: white;
  overflow: hidden;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">

<h2>Example</h2>
<button class="test2">ADD</button>

<div class="samplesinfo hidden">
  <div class="test">
    <button class="delbtn">Delete</button>
    <button class="accordion">Button</button>
    <div class="panel">
      <input type="text" name="test">
    </div>
  </div>
</div>

Обратите внимание, что id s должно быть уникальным.
this - мощное ключевое слово, когда вы хотите нацелить элемент относительнотекущий (тот, на котором вы вызвали событие).

⋅ ⋅ ⋅

А вот версия JavaScript…

Слушатели событий не копируются с JavaScript,поэтому нам нужно вызывать функцию каждый раз, когда мы добавляем новый элемент!…

Фрагмент:

var index = 0;
var template = document.querySelector(".samplesinfo.hidden");

document.querySelector(".test2").onclick = function() {
  var element = template.cloneNode(true);
  element.classList.remove('hidden');
  element.querySelector('.delbtn').innerText = 'Delete ' + ++index;
  var samples = document.querySelectorAll(".samplesinfo");
  var last = samples[samples.length - 1];
  last.parentNode.insertBefore(element, last.nextSibling);
  refresh_listeners();  
}

// Event listeners are not copied with JavaScript, so we need to call this function each time we add a new element!…
function refresh_listeners() {
  document.querySelectorAll(".accordion").forEach(function(elm) {
    elm.onclick = function() {
      elm.nextElementSibling.classList.toggle("hidden");
    }
  });
  document.querySelectorAll(".delbtn").forEach(function(elm) {
    elm.onclick = function() {
      elm.closest(".samplesinfo").outerHTML = '';
    }
  });
}

// Trigger click
document.querySelector(".test2").click();
.hidden {
  display: none;
}

.accordion {
  background-color: #eee;
  color: #444;
  cursor: pointer;
  padding: 18px;
  width: 100%;
  border: none;
  text-align: left;
  outline: none;
  font-size: 15px;
  transition: 0.4s;
  float: left;
}

.delbtn {
  float: right;
}

.active,
.accordion:hover {
  background-color: #ccc;
}

.panel {
  padding: 0 18px;
  background-color: white;
  overflow: hidden;
}
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">

<h2>Example</h2>
<button class="test2">ADD</button>

<div class="samplesinfo hidden">
  <div class="test">
    <button class="delbtn">Delete</button>
    <button class="accordion">Button</button>
    <div class="panel hidden">
      <input type="text" name="test">
    </div>
  </div>
</div>

Надеюсь, это поможет.

0 голосов
/ 08 июня 2018

Идентификаторы в HTML должны быть уникальными , здесь в качестве примера я использовал классы CSS.Вам необходимо нацелить элемент в текущем элементе, т.е. this context

$(document).ready(function() {
  $(".test2").click(function() {
    var element = $(".samplesinfo:first").clone(true);
    
    element.insertAfter(".samplesinfo:last");

    //Get all delbtn
    var delbtns = $('.delbtn');

    //get last elements index
    var index = delbtns.index(delbtns.last()) + 1;

    //set Text
    element.find('.delbtn').text('Delete' + index)
  });
  
  $(".accordion").click(function() {
    $(this).next(".panel").toggle();
  });
  $(".delbtn").click(function() {
    $(this).closest(".samplesinfo").remove();
  });
});
.accordion {
  background-color: #eee;
  color: #444;
  cursor: pointer;
  padding: 18px;
  width: 100%;
  border: none;
  text-align: left;
  outline: none;
  font-size: 15px;
  transition: 0.4s;
}

.active,
.accordion:hover {
  background-color: #ccc;
}

.panel {
  padding: 0 18px;
  display: none;
  background-color: white;
  overflow: hidden;
}

.close {
  float: right;
  padding: 12px 16px 12px 16px;
}

.close:hover {
  background-color: #f44336;
  color: white;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">

<h2>Example</h2>
<button class="test2">ADD</button>

<div class="samplesinfo">
  <div class="test">
    <button class="delbtn" style="float: right;">Delete</button>
    <button id="sample" class="accordion" style="float: left;">Button</button>
    <div id="usrInput" class="panel">
      <input type="text" name="test">
    </div>
  </div>
</div>
<div class="paste">
</div>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...