jQuery zduplikować DIV do innego DIV

101

Potrzebujesz pomocy jQuery w kopiowaniu DIV do innego DIV i mam nadzieję, że jest to możliwe. Mam następujący HTML:

  <div class="container">
  <div class="button"></div>
  </div>

A potem mam kolejny DIV w innej lokalizacji na mojej stronie i chciałbym skopiować element div „button” do następującego div „package”:

<div class="package">

Place 'button' div in here

</div>
Dan
źródło

Odpowiedzi:

164

Będziesz chciał użyć clone()metody, aby uzyskać głęboką kopię elementu:

$(function(){
  var $button = $('.button').clone();
  $('.package').html($button);
});

Pełne demo: http://jsfiddle.net/3rXjx/

Z dokumentacji jQuery :

Metoda .clone () wykonuje głęboką kopię zestawu dopasowanych elementów, co oznacza, że ​​kopiuje dopasowane elementy, a także wszystkie ich elementy podrzędne i węzły tekstowe. W połączeniu z jedną z metod wstawiania .clone () to wygodny sposób na powielenie elementów na stronie.

chrx
źródło
1
Nie zachowuje to wartości dodanych przez użytkownika na wejściach.
wtf8_decode,
6
czy możesz mi powiedzieć, dlaczego musimy $się var $button. Wierzę, że w js można zadeklarować var ​​po prostu jako var button.
KNU
20
@KNU Nie jest to konieczne, ale jest to powszechna konwencja w świecie jQuery. Wskazuje, że zmienna przycisku $ jest obiektem jQuery. Zobacz stackoverflow.com/questions/205853/…
chrx
21

Skopiuj kod za pomocą funkcji clone i appendTo:

Oto działający przykład jsfiddle

<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script>
</head>
<body>
<div id="copy"><a href="http://brightwaay.com">Here</a> </div>
<br/>
<div id="copied"></div>
<script type="text/javascript">
    $(function(){
        $('#copy').clone().appendTo('#copied');
    });
</script>
</body>
</html>
Sunny SM
źródło
3

Możesz skopiować swój element div w ten sposób

$(".package").html($(".button").html())
JAVAGeek
źródło
2

Umieść to na wydarzeniu

$(function(){
    $('.package').click(function(){
       var content = $('.container').html();
       $(this).html(content);
    });
});
Muhammad Raheel
źródło
0

$(document).ready(function(){  
    $("#btn_clone").click(function(){  
        $("#a_clone").clone().appendTo("#b_clone");  
    });  
});  
.container{
    padding: 15px;
    border: 12px solid #23384E;
    background: #28BAA2;
    margin-top: 10px;
}
<!DOCTYPE html>  
<html>  
<head>  
<title>jQuery Clone Method</title> 
<script src="https://code.jquery.com/jquery-3.3.1.min.js"></script> 


</head>  
<body> 
<div class="container">
<p id="a_clone"><b> This is simple example of clone method.</b></p>  
<p id="b_clone"><b>Note:</b>Click The Below button Click Me</p>  
<button id="btn_clone">Click Me!</button>  
</div> 
</body>  
</html>  

Więcej szczegółów i demo

Deweloper
źródło