Os códigos QR não são do agrado de todos, mas eu gosto muito deles. Se vejo algo que quero lembrar ou verificar mais tarde, especialmente quando estou na estrada, é muito fácil tirar uma foto rápida – é muito mais fácil do que tentar lembrar um URL e muito mais rápido do que digitá-lo em um teclado minúsculo.

Se o senhor precisar gerar códigos QR, para um cliente ou para si mesmo, há um projeto JavaScript muito bom: node-qrcode. Vamos dar uma olhada nas diferentes formas e formatos de saída que o senhor pode usar para criar um código QR!

Comece instalando a biblioteca:

yarn add qrcode

Criar dados de imagem de código QR

Com o utilitário de código QR disponível, o senhor pode gerar um URI de dados para o código QR que pode ser usado com um <img> :

const generateQR = async text => {
  try {
    console.log(await QRCode.toDataURL(text))
  } catch (err) {
    console.error(err)
  }
}

generateQR("https://davidwalsh.name");

/*

*/

Criar um código QR no Terminal

Se quiser ver o código QR no terminal via Node.js, o senhor pode fazer isso passando um objeto de configuração:

const generateQR = async text => {
  try {
    console.log(await QRCode.toString(text, {type: 'terminal'}))
  } catch (err) {
    console.error(err)
  }
}

Criar uma imagem de código QR

O senhor pode gerar uma imagem PNG, SVG ou UTF8 para o código QR:

const generateQR = async text => {
  try {
    await QRCode.toFile('./davidwash-qr-code.png', text);
  } catch (err) {
    console.error(err)
  }
}

Criar um código QR no Canvas

Se você usar um utilitário como o Browserify e o webpack, poderá usar o qrcode no lado do cliente:

var canvas = document.getElementById('canvas');
const generateQR = async text => {
  try {
    await QRCode.toCanvas(canvas, text)
  } catch (err) {
    console.error(err)
  }
}

generateQR("https://davidwalsh.name");

Essa incrível biblioteca de código QR também permite que o senhor crie muito mais do que mostrei aqui, inclusive dados binários e com uma variedade de opções. Se o senhor precisar criar um código QR, não precisa procurar mais node-qr código!