Saltar al contenido principal

Enviar tokens usando ethers.js

ETHERS.JS
ERC-20
TOKENS
Principiante
Kim YongJun
6 de abril de 2021
3 minutos de lectura

Enviar tokens usando ethers.js(5.0)

En este tutorial aprenderá a

  • Importar ethers.js
  • Transferir tokens
  • Establecer el precio del gas según la situación del tráfico de la red

Para empezar

Para empezar, primero debemos importar la biblioteca ethers.js en nuestro JavaScript Incluir ethers.js(5.0)

Instalación

/home/ricmoo> npm install --save ethers

ES6 en el navegador

<script type="module">
  import { ethers } from "https://cdn.ethers.io/lib/ethers-5.0.esm.min.js"
  // Tu código aquí...
</script>

ES3(UMD) en el navegador

<script
  src="https://cdn.ethers.io/lib/ethers-5.0.umd.min.js"
  type="application/javascript"
></script>

Parámetros

  1. contract_address: Dirección del contrato del token (la dirección del contrato es necesaria cuando el token que desea transferir no es ether)
  2. send_token_amount: La cantidad que desea enviar al receptor
  3. to_address: La dirección del receptor
  4. send_account: La dirección del remitente
  5. private_key: Clave privada del remitente para firmar la transacción y transferir realmente los tokens

Aviso

Se elimina signTransaction(tx) porque sendTransaction() lo hace internamente.

Procedimientos de envío

1. Conectarse a la red (red de prueba)

Configurar el proveedor (Infura)

Conectarse a la red de prueba Ropsten

window.ethersProvider = new ethers.providers.InfuraProvider("ropsten")

2. Crear billetera

let wallet = new ethers.Wallet(private_key)

3. Conectar la billetera a la red

let walletSigner = wallet.connect(window.ethersProvider)

4. Obtener el precio del gas actual

window.ethersProvider.getGasPrice() // gasPrice

5. Definir la transacción

Estas variables definidas a continuación dependen de send_token()

Parámetros de la transacción

  1. send_account: dirección del remitente del token
  2. to_address: dirección del receptor del token
  3. send_token_amount: la cantidad de tokens a enviar
  4. gas_limit: límite de gas
  5. gas_price: precio del gas

Consulte a continuación cómo usarlo

const tx = {
  from: send_account,
  to: to_address,
  value: ethers.utils.parseEther(send_token_amount),
  nonce: window.ethersProvider.getTransactionCount(send_account, "latest"),
  gasLimit: ethers.utils.hexlify(gas_limit), // 100000
  gasPrice: gas_price,
}

6. Transferencia

walletSigner.sendTransaction(tx).then((transaction) => {
  console.dir(transaction)
  alert("Send finished!")
})

Cómo usarlo

¡Éxito!

image of transaction done successfully

send_token()