Copiando texto para área de transferência em JavaScript

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

[ Hits: 9.192 ]

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

Python - capturar a saída do programa em um arquivo ou variável

Imagens flutuantes no Desktop

Javascript - pegar um elemento aleatório de uma lista

Tema Escuro no Chrome Developer Tools (Dark Mode)

Resolvendo problema de renderização de fontes no Firefox [Debian]

Leitura recomendada

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

Codificação HEXADECIMAL para HTML

Ativando Player HTML5 no YouTube

Adicionar Facebook Comments no Google Sites

Skype Web - Alternativa ao Skype desktop

  

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