Copiando texto para área de transferência em JavaScript

Publicado por Fábio Berbert de Paula em 19/06/2020

[ Hits: 8.635 ]

Blog: https://fabio.automatizando.dev

 


Copiando texto para área de transferência em JavaScript



Existem duas formas de se copiar texto para a área de transferência usando vanilla JavaScript. Uma delas é usando um objeto do tipo input. Exemplo:

<input value="Este texto será copiado" />
<button>Copiar</button>

<script>
document.querySelector("button").addEventListener("click",
function (event) {
        document.querySelector("input").select()
        document.execCommand('copy')
})
</script>

A outra é usando qualquer elemento do tipo "contentEditable". Exemplo:

<p id="texto" contentEditable>Este texto será copiado.</p>
<button>Copiar</button>

<script>
document.querySelector("button").addEventListener("click",
function (event) {

        document.querySelector("p").focus()
        document.execCommand('selectAll', false, null)
        document.execCommand('copy')
})
</script>

Em navegadores mais modernos já existe uma terceira forma, que é usando a Clipboard API (navigator.clipboard), mas como o código ainda não é compatível com a maioria dos navegadores, vou encerrar a dica somente citando essa hipótese.

Até a próxima!

Outras dicas deste autor

Google Authenticator no terminal Linux

Criando aplicativos multiplataforma (Android, iOS, Windows) com Python + Kivy

PHP - Como comparar duas strings case insensitive

online_man - Páginas de manual online no terminal

Como escrever em arquivos protegidos usando o sudo e redirecionamento

Leitura recomendada

Ativando Player HTML5 no YouTube

Como instalar Deno no Linux

Comandos rápidos para Mozilla/Firefox

Skype Web - Alternativa ao Skype desktop

Sistemas de conteúdo em Webserver de projeto pessoal em ambiente SourceForge

  

Comentários

Nenhum comentário foi encontrado.



Contribuir com comentário




Patrocínio

Site hospedado pelo provedor RedeHost.
Linux banner

Destaques

Artigos

Dicas

Tópicos

Top 10 do mês

Scripts