Saltar al contenido principal

Envío de tokens usando ethers.js

ETHERS.JS
ERC-20
TOKENS
Principiante
Kim YongJun
6 de abril de 2021
3 minuto leído

Enviar un token usando ethers.js(5.0)

En este tutorial aprenderá a:

  • Importar ethers.js
  • Transferir un token
  • 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. Incluya 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"
  // Su 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 quiere transferir no es ether)
  2. send_token_amount: la cantidad que quiere enviar al receptor
  3. to_address: la dirección del receptor
  4. send_account: la dirección del emisor
  5. private_key: la clave privada del emisor para firmar la transacción y transferir los tokens

Aviso

signTransaction(tx) se eliminó porque sendTransaction() lo hace internamente.

Procedimientos de envío

1. Conectarse a la red (red de prueba)

Establecer el proveedor (Infura)

Conectarse a la red de prueba Ropsten

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

2. Crear una 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 actual del gas

window.ethersProvider.getGasPrice() // gasPrice

5. Definir la transacción

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

Parámetros de la transacción

  1. send_account: dirección del emisor 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

Vea 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("¡Envío finalizado!")
})

Cómo usarlo

¡Éxito!

imagen de la transacción realizada con éxito

send_token()

Última actualización de la página: 3 de marzo de 2026

¿Te resultó útil este tutorial?