Tự học Web3: Subscribing to Events. Lắng nghe sự kiện từ một hợp đồng được viết bằng Solidity bằng Web3.js
Subscribing to Events
Tự học Web3: Lắng nghe sự kiện từ một hợp đồng được viết bằng Solidity bằng Web3.js
Đăng ký sự kiện
Như bạn có thể thấy, việc tương tác với hợp đồng của bạn thông qua Web3.js khá đơn giản - khi bạn đã thiết lập môi trường của mình, việc gọi các hàm và gửi giao dịch không khác gì một API web thông thường.
Có một khía cạnh khác mà trong bài giảng ngày hôm nay chúng ta sẽ nghiên cứu: Đăng ký lắng nghe các sự kiện từ hợp đồng Solidity của bạn từ Web3.js
Lắng nghe những thây ma mới
Nếu bạn nhớ lại từ zombiefactory.sol, chúng ta đã có một sự kiện gọi là NewZombie mà chúng tôi đã bắn mỗi khi một thây ma mới được tạo ra:
event NewZombie(uint zombieId, string name, uint dna);
Trong Web3.js, bạn có thể đăng ký lắng nghe một sự kiện để nhà cung cấp web3 của bạn sẽ kích hoạt logic trong mã của bạn mỗi khi nó kích hoạt:
cryptoZombies.events.NewZombie()
.on("data", function(event) {
let zombie = event.returnValues;
// We can access this event's 3 return values on the `event.returnValues` object:
console.log("A new zombie was born!", zombie.zombieId, zombie.name, zombie.dna);
}).on("error", console.error);
Lưu ý rằng điều này sẽ kích hoạt cảnh báo mỗi khi BẤT KỲ zombie nào được tạo trong DApp của chúng ta - không chỉ riêng cho người dùng hiện tại. Điều gì sẽ xảy ra nếu chúng tôi chỉ muốn thông báo cho người dùng hiện tại?
Sử dụng đã lập chỉ mục. Using indexed
Để lọc các sự kiện và chỉ lắng nghe các thay đổi liên quan đến người dùng hiện tại, hợp đồng Solidity của chúng ta sẽ phải sử dụng từ khóa được lập chỉ mục, giống như chúng tôi đã làm trong sự kiện Chuyển giao khi triển khai ERC721 của chúng tôi:
event Transfer(address indexed _from, address indexed _to, uint256 _tokenId);
Trong trường hợp này, vì _from và _to được lập chỉ mục, điều đó có nghĩa là chúng ta có thể lọc chúng trong trình xử lý sự kiện ở giao diện người dùng:
// Use `filter` to only fire this code when `_to` equals `userAccount`
cryptoZombies.events.Transfer({ filter: { _to: userAccount } })
.on("data", function(event) {
let data = event.returnValues;
// The current user just received a zombie!
// Do something here to update the UI to show it
}).on("error", console.error);
Như bạn có thể thấy, sử dụng các sự kiện và các trường được lập chỉ mục có thể là một phương pháp khá hữu ích để lắng nghe các thay đổi đối với hợp đồng của bạn và phản ánh chúng trong giao diện người dùng của ứng dụng.
Truy vấn các sự kiện trước đây. Querying past events
Chúng ta thậm chí có thể truy vấn các sự kiện trong quá khứ bằng cách sử dụng getPastEvents và sử dụng các bộ lọc fromBlock và toBlock để cung cấp cho Solidity một phạm vi thời gian cho các bản ghi sự kiện ("block" trong trường hợp này là số khối Ethereum):
cryptoZombies.getPastEvents("NewZombie", { fromBlock: 0, toBlock: "latest" })
.then(function(events) {
// `events` is an array of `event` objects that we can iterate, like we did above
// This code will get us a list of every zombie that was ever created
});
Bởi vì bạn có thể sử dụng phương pháp này để truy vấn nhật ký sự kiện quá khứ. Điều này đưa ra một trường hợp sử dụng thú vị: Sử dụng sự kiện như một hình thức lưu trữ rẻ hơn.
Nếu bạn nhớ lại, lưu dữ liệu vào blockchain là một trong những hoạt động tốn kém nhất trong Solidity. Nhưng sử dụng sự kiện rẻ hơn nhiều về chi phí gas.
Bạn phải cân đối giữa tiết kiệm và tiện lợi ở đây là các sự kiện không thể đọc được từ bên trong chính hợp đồng thông minh. Nhưng đó là một trường hợp sử dụng quan trọng cần lưu ý nếu bạn có một số dữ liệu bạn muốn được ghi lại lịch sử trên blockchain để bạn có thể đọc nó từ giao diện người dùng của ứng dụng.
Ví dụ: chúng ta có thể sử dụng điều này làm hồ sơ lịch sử về các trận chiến thây ma. Chúng tôi có thể tạo một sự kiện cho mỗi khi một thây ma tấn công một thây ma khác và ai là người chiến thắng. Hợp đồng thông minh không cần dữ liệu này, nhưng đó là dữ liệu hữu ích để người dùng có thể duyệt từ giao diện người dùng của ứng dụng.
HỌC TỪ ĐẦU: BÀI SỐ 1