Przejdź do głównej treści

Skonfiguruj Web3.js, aby korzystać z blockchaina Ethereum w JavaScript

web3.js
JavaScript
Początkujący
jdourlens
11 kwietnia 2020
3 minut czytania

W tym samouczku zobaczymy, jak zacząć pracę z Web3.js (opens in a new tab), aby wchodzić w interakcje z blockchainem Ethereum. Web3.js może być używane zarówno we frontendzie, jak i backendzie do odczytywania danych z blockchaina, wykonywania transakcji, a nawet wdrażania inteligentnych kontraktów.

Pierwszym krokiem jest dołączenie Web3.js do Twojego projektu. Aby użyć go na stronie internetowej, możesz zaimportować bibliotekę bezpośrednio za pomocą CDN, takiego jak JSDeliver.

<script src="https://cdn.jsdelivr.net/npm/web3@latest/dist/web3.min.js"></script>

Jeśli wolisz zainstalować bibliotekę, aby używać jej w backendzie lub projekcie frontendowym wykorzystującym proces budowania (build), możesz zainstalować ją za pomocą npm:

npm install web3 --save

Następnie, aby zaimportować Web3.js do skryptu Node.js lub projektu frontendowego Browserify, możesz użyć następującej linijki w JavaScript:

const Web3 = require("web3")

Teraz, gdy dołączyliśmy bibliotekę do projektu, musimy ją zainicjować. Twój projekt musi być w stanie komunikować się z blockchainem. Większość bibliotek Ethereum komunikuje się z węzłem poprzez wywołania RPC. Aby zainicjować naszego dostawcę Web3, utworzymy instancję Web3, przekazując jako konstruktor adres URL dostawcy. Jeśli masz węzeł lub instancję ganache uruchomioną na swoim komputerze (opens in a new tab), będzie to wyglądać tak:

const web3 = new Web3("http://localhost:8545")

Jeśli chcesz uzyskać bezpośredni dostęp do hostowanego węzła, możesz znaleźć opcje w sekcji węzły jako usługa (nodes as a service).

const web3 = new Web3("https://cloudflare-eth.com")

Aby sprawdzić, czy poprawnie skonfigurowaliśmy naszą instancję Web3, spróbujemy pobrać numer najnowszego bloku za pomocą funkcji getBlockNumber. Funkcja ta przyjmuje wywołanie zwrotne (callback) jako parametr i zwraca numer bloku jako liczbę całkowitą.

var Web3 = require("web3")
const web3 = new Web3("https://cloudflare-eth.com")

web3.eth.getBlockNumber(function (error, result) {
  console.log(result)
})

Jeśli wykonasz ten program, po prostu wydrukuje on numer najnowszego bloku: szczyt blockchaina. Możesz również użyć wywołań funkcji await/async, aby uniknąć zagnieżdżania wywołań zwrotnych w swoim kodzie:

async function getBlockNumber() {
  const latestBlockNumber = await web3.eth.getBlockNumber()
  console.log(latestBlockNumber)
  return latestBlockNumber
}

getBlockNumber()

Wszystkie funkcje dostępne w instancji Web3 można znaleźć w oficjalnej dokumentacji Web3.js (opens in a new tab).

Większość bibliotek Web3 jest asynchroniczna, ponieważ w tle biblioteka wykonuje wywołania JSON-RPC do węzła, który odsyła wynik.


Jeśli pracujesz w przeglądarce, niektóre portfele bezpośrednio wstrzykują instancję Web3 i powinieneś starać się jej używać, gdy tylko jest to możliwe, zwłaszcza jeśli planujesz wchodzić w interakcje z adresem Ethereum użytkownika w celu wykonywania transakcji.

Oto fragment kodu pozwalający wykryć, czy portfel MetaMask jest dostępny, i spróbować go włączyć, jeśli tak. Pozwoli to później na odczytanie salda użytkownika i umożliwi mu zatwierdzanie transakcji, które chciałbyś, aby wykonał na blockchainie Ethereum:

Istnieją również alternatywy dla Web3.js, takie jak Ethers.js (opens in a new tab), które są powszechnie używane. W następnym samouczku zobaczymy, jak łatwo nasłuchiwać nowych przychodzących bloków na blockchainie i sprawdzać, co zawierają (opens in a new tab).