jQuery duplicar DIV em outro DIV

100

Precisa de ajuda do jquery para copiar um DIV para outro DIV e espero que isso seja possível. Eu tenho o seguinte HTML:

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

E então eu tenho outro DIV em outro local em minha página e gostaria de copiar o div 'botão' para o seguinte div 'pacote':

<div class="package">

Place 'button' div in here

</div>
Dan
fonte

Respostas:

163

Você vai querer usar o clone()método para obter uma cópia profunda do elemento:

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

Demonstração completa: http://jsfiddle.net/3rXjx/

Dos documentos jQuery :

O método .clone () executa uma cópia profunda do conjunto de elementos correspondentes, o que significa que ele copia os elementos correspondentes, bem como todos os seus elementos descendentes e nós de texto. Quando usado em conjunto com um dos métodos de inserção, .clone () é uma maneira conveniente de duplicar elementos em uma página.

chrx
fonte
1
Isso não mantém os valores adicionados pelo usuário nas entradas.
wtf8_decode
6
pode dizer-me por isso que precisamos $nos var $button. Eu acredito em js que você pode declarar var simplesmente como var button.
KNU
20
@KNU Não é necessário, mas é uma convenção comum no mundo jQuery. Indica que a variável $ button é um objeto jQuery. Consulte stackoverflow.com/questions/205853/…
chrx
21

Copie o código usando a função clone e appendTo:

Aqui também está o exemplo de trabalho 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
fonte
3

Você pode copiar seu div assim

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

Coloque isso em um evento

$(function(){
    $('.package').click(function(){
       var content = $('.container').html();
       $(this).html(content);
    });
});
Muhammad Raheel
fonte
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 mais detalhes e demonstração

Desenvolvedor
fonte