I've been revisiting ethers.js
recently to refresh my understanding of the details and to write a simple tutorial called "WTF Ethers" for beginners.
Twitter: @0xAA_Science
Community: Website wtf.academy | WTF Solidity | discord | WeChat Group Application
All the code and tutorials are open-sourced on GitHub: github.com/WTFAcademy/WTF-Ethers
In this lesson, we will introduce the ethers.js
library and write our first program, HelloVitalik
: it will query Vitalik's ETH balance and output it to the console.
This tutorial uses the latest version of ethers.js, v6, which has significant changes compared to v5. For v5 tutorial, please check link.
Overview of ethers.js
ethers.js
is a complete and compact open-source library for interacting with the Ethereum blockchain and its ecosystem. If you want to build a frontend for a Dapp or write a script to interact with Ethereum, you will need to use ethers.js
.
Compared to the earlier library web3.js
, ethers.js
has the following advantages:
- More compact code:
ethers.js
is 210.2 kB, whileweb3.js
is 590.6 kB. - More secure:
Web3.js
assumes that users will deploy a local Ethereum node, and the private keys and network connectivity are managed by this node (which is not actually the case); inethers.js
, theProvider
class manages network connectivity, while theWallet
class manages keys, making it more secure and flexible. - Native support for
ENS
.
data:image/s3,"s3://crabby-images/973e5/973e592aa619c32f1743726eb993dbb26a3f4a89" alt="ethers.js connecting Dapp frontend and the blockchain"
Development Tools
1. VScode (recommended)
You can use local vscode
for development. You need to install Node.js, and then use the package manager npm
to install the ethers
library:
2. Playcode (unstable)
data:image/s3,"s3://crabby-images/b9cdd/b9cdd7c0d32f2f60f9a902f0a37dd5f9c15da435" alt="playcode"
Playcode is an online platform for compiling JavaScript. You can run .js
files without configuring Nodejs
, which is very convenient.
data:image/s3,"s3://crabby-images/6f6b5/6f6b5057272861a78693465178aeee5017c8d3ce" alt="playcode"
You need to register a free account on the official website, then create a new project with the Javascript
template by clicking OPEN PLAYGROUND
, and write the code in the auto-generated script.js
file. However, playcode
may not be stable when using ethers
, so we recommend using VScode
as we will be using it to demonstrate this chapter.
Note: When running for the first time on playcode
, it may prompt module not found
. This is because the ethers
library has not been installed, simply click the install
button to install it. If this does not work, please use VScode locally.
HelloVitalik
Now, let's write our first program using ethers
called HelloVitalik
: it will query Vitalik's ETH balance and output it to the console. The entire program only requires 7 lines, very simple!
data:image/s3,"s3://crabby-images/f754c/f754c356c1b54be7896fd949e92a58f0d29a94da" alt="Hello Vitalik"
Let's analyze the program line by line:
1. Import ethers
The first line fetches the installed ethers
library:
If you are using the playcode
platform where free accounts cannot install external libraries, you can directly import from the ethers
CDN (for educational purposes only due to security considerations):
2. Connect to Ethereum
In ethers
, the Provider
class is an abstract class that provides Ethereum network connectivity. It provides read-only access to the blockchain and its state. We declare a provider
to connect to the Ethereum network. ethers
provides some common RPCs for easy connection to Ethereum:
Note: The built-in rpc
in ethers
has limitations on access speed and is for testing purposes only. In a production environment, it is recommended to use a personal rpc
. For example:
3. Declare the address you want to query
In this case, Vitalik address. We can copy paste the address but since ethers
natively supports ENS
domain names, we can query the balance of Ethereum founder Vitalik's address using the ENS
domain name vitalik.eth
4. Get an async
function
Since interactions with the blockchain are not real-time, we need to use the async/await
syntax in JavaScript. Each call with the blockchain requires the use of await
, and we wrap these calls in an async
function.
5. Get the ETH
balance of Vitalik's address
We can use the getBalance()
function of the Provider
class to query the ETH
balance of a specific address. Since we have already declared a function for Vitalik's address, we can simply call it out here
6. Convert units and output to the console
The Ethereum balance we obtained from the chain is in wei
, where 1 ETH = 10^18 wei
. Before printing it to the console, we need to convert the units. ethers
provides a utility function called formatEther
, which we can use to convert wei
to ETH
.
If you are using the VScode development tool, you need to enter the following command in the VScode terminal to run the script:
This way, you will see Vitalik's ETH
balance in the console: 82.07 ETH
. Of course, this is not his entire holdings. He has multiple wallets, and vitalik.eth
is likely one of his frequently used hot wallets.
data:image/s3,"s3://crabby-images/4bedb/4bedb8bad57a5c36bc9ca71483fd12e34355034f" alt="Printing Vitalik's balance to the console"
Summary
This concludes the first lesson of the WTF Ethers tutorial. We introduced ethers.js
and completed our first program using ethers
: HelloVitalik
, which queries Vitalik's wallet balance.
Post-Class Assignment: Substitute Vitalik's address for other addresses (or your address) to query the ETH balance.