Copiando texto para área de transferência em JavaScript

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

[ Hits: 9.461 ]

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

ffmpeg - Como aumentar ou reduzir o volume de um áudio ou video via linha de comando

Como Instalar as Fontes TrueType da Microsoft no Debian 12

Habilitando conversão de PDF em Imagem usando o ImageMagick

Como limpar o cache DNS no Google Chrome

Apagando linhas em branco no vim

Leitura recomendada

JavaScript - verificar se todos os itens de um array são pares ou ímpares

Skype Web - Alternativa ao Skype desktop

Ativando Player HTML5 no YouTube

Adicionar Facebook Comments no Google Sites

Bloqueando objetos Flash de páginas

  

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