jQuery duplicar DIV en otro DIV

100

Necesito ayuda de jquery para copiar un DIV en otro DIV y espero que esto sea posible. Tengo el siguiente HTML:

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

Y luego tengo otro DIV en otra ubicación en mi página y me gustaría copiar el div del 'botón' en el siguiente div del 'paquete':

<div class="package">

Place 'button' div in here

</div>
Dan
fuente

Respuestas:

163

Querrá usar el clone()método para obtener una copia profunda del elemento:

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

Demostración completa: http://jsfiddle.net/3rXjx/

De los documentos de jQuery :

El método .clone () realiza una copia profunda del conjunto de elementos coincidentes, lo que significa que copia los elementos coincidentes, así como todos sus elementos descendientes y nodos de texto. Cuando se usa junto con uno de los métodos de inserción, .clone () es una forma conveniente de duplicar elementos en una página.

chrx
fuente
1
Esto no mantiene los valores agregados por el usuario en las entradas.
wtf8_decode
6
Puede usted decirme por qué necesitamos $en var $button. Creo en js puedes declarar var simplemente como var button.
KNU
20
@KNU No es necesario, pero es una convención común en el mundo jQuery. Indica que la variable $ button es un objeto jQuery. Ver stackoverflow.com/questions/205853/…
chrx
21

Copie el código usando la función clon y appendTo:

Aquí también hay un ejemplo de trabajo 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>
Soleado SM
fuente
3

Puedes copiar tu div así

$(".package").html($(".button").html())
JAVAGeek
fuente
2

Pon esto en un evento

$(function(){
    $('.package').click(function(){
       var content = $('.container').html();
       $(this).html(content);
    });
});
Muhammad Raheel
fuente
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>  

Para más detalles y demostración

Desarrollador
fuente