jQuery duplica DIV in un altro DIV


100

Hai bisogno di aiuto jquery per copiare un DIV in un altro DIV e sperando che questo sia possibile. Ho il seguente codice HTML:

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

E poi ho un altro DIV in un'altra posizione nella mia pagina e vorrei copiare il div "pulsante" nel seguente div "pacchetto":

<div class="package">

Place 'button' div in here

</div>

Risposte:


163

Ti consigliamo di utilizzare il clone()metodo per ottenere una copia completa dell'elemento:

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

Demo completa: http://jsfiddle.net/3rXjx/

Dai documenti jQuery :

Il metodo .clone () esegue una copia completa del set di elementi corrispondenti, il che significa che copia gli elementi corrispondenti così come tutti i loro elementi discendenti e nodi di testo. Quando viene utilizzato insieme a uno dei metodi di inserimento, .clone () è un modo conveniente per duplicare gli elementi su una pagina.


1
Ciò non mantiene i valori aggiunti dall'utente sugli input.
wtf8_decode

6
può dirmi il motivo per cui abbiamo bisogno $in var $button. Credo in js che puoi dichiarare var semplicemente come var button.
KNU

20
@KNU Non è necessario ma è una convenzione comune nel mondo jQuery. Indica che la variabile $ button è un oggetto jQuery. Vedere stackoverflow.com/questions/205853/...
chrx

21

Copia il codice usando clone e appendTo function:

Ecco anche un esempio funzionante 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>

3

Puoi copiare il tuo div in questo modo

$(".package").html($(".button").html())

2

Metti questo su un evento

$(function(){
    $('.package').click(function(){
       var content = $('.container').html();
       $(this).html(content);
    });
});

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>  

Per maggiori dettagli e demo

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.