Chuyển đến nội dung chính

Bài 13: Tự học lập trình Solidity. Web3.js - Giới thiệu về thư viện Javascript Web3.js của Ethereum

Javascript Web3.js

Giới thiệu về thư viện Javascript Web3.js của Ethereum.



Hợp đồng về Zombie viết bằng ngôn ngữ lập trình Solidity trong ví dụ của chúng ta đã hoàn tất! Bây giờ chúng ta cần viết một giao diện người dùng javascript tương tác với hợp đồng.

Ethereum có một thư viện Javascript được gọi là Web3.js.

Trong bài học sau, chúng ta sẽ đi sâu hơn về cách triển khai hợp đồng và thiết lập Web3.js. Nhưng bây giờ chúng ta hãy xem một số mã mẫu để biết cách Web3.js sẽ tương tác với hợp đồng Zombie.

Đừng lo lắng nếu bạn chưa hiểu hết được đoạn code này, sẽ có giải thích ở phần dưới.

// Here's how we would access our contract:
var abi = /* abi generated by the compiler */
var ZombieFactoryContract = web3.eth.contract(abi)
var contractAddress = /* our contract address on Ethereum after deploying */
var ZombieFactory = ZombieFactoryContract.at(contractAddress)
// `ZombieFactory` has access to our contract's public functions and events

// some sort of event listener to take the text input:
$("#ourButton").click(function(e) {
  var name = $("#nameInput").val()
  // Call our contract's `createRandomZombie` function:
  ZombieFactory.createRandomZombie(name)
})

// Listen for the `NewZombie` event, and update the UI
var event = ZombieFactory.NewZombie(function(error, result) {
  if (error) return
  generateZombie(result.zombieId, result.name, result.dna)
})

// take the Zombie dna, and update our image
function generateZombie(id, name, dna) {
  let dnaStr = String(dna)
  // pad DNA with leading zeroes if it's less than 16 characters
  while (dnaStr.length < 16)
    dnaStr = "0" + dnaStr

  let zombieDetails = {
    // first 2 digits make up the head. We have 7 possible heads, so % 7
    // to get a number 0 - 6, then add 1 to make it 1 - 7. Then we have 7
    // image files named "head1.png" through "head7.png" we load based on
    // this number:
    headChoice: dnaStr.substring(0, 2) % 7 + 1,
    // 2nd 2 digits make up the eyes, 11 variations:
    eyeChoice: dnaStr.substring(2, 4) % 11 + 1,
    // 6 variations of shirts:
    shirtChoice: dnaStr.substring(4, 6) % 6 + 1,
    // last 6 digits control color. Updated using CSS filter: hue-rotate
    // which has 360 degrees:
    skinColorChoice: parseInt(dnaStr.substring(6, 8) / 100 * 360),
    eyeColorChoice: parseInt(dnaStr.substring(8, 10) / 100 * 360),
    clothesColorChoice: parseInt(dnaStr.substring(10, 12) / 100 * 360),
    zombieName: name,
    zombieDescription: "A Level 1 CryptoZombie",
  }
  return zombieDetails
}

Giải thích: 
Những gì javascript nhận một đầu vào là tên tên của Zombile mà người dùng nhập trong textbox nameInput.
Hợp đồng zombie (mà ta đã ghi nhớ từ các bài học trước) có tên là ZombieFactory sẽ tạo mới một zombie từ tên nameInput đó.
Tiếp đó ZombieFactory trả ngược lại kết quả cho Javascript của zombie mới tạo được bao gồm:  zomebieId, name và dna.
Từ 3 dữ liệu này javascript sử dụng một số thay đổi dựa trên trình duyệt (chúng ta đang sử dụng Vue.js) để hoán đổi hình ảnh và áp dụng các bộ lọc CSS. Bạn sẽ nhận được học điều này trong một bài học sau.


Nếu bạn chưa biết cách TẠO FILE, COMPILER và DEPLOY thì hãy xem lại trong bài giới thiệu nhé. Có hướng dẫn chi tiết ở đó.



BÀI TIẾP THEO: BÀI SỐ 14

HỌC TỪ ĐẦU: BÀI SỐ 1

Bài đăng phổ biến từ blog này

Bài giới thiệu: Tự học Solidity. Học lập trình web3. Lập trình Smart Contract các Blockchain

LỜI NÓI ĐẦU Mục đích của blog này để chia sẻ một cách đơn giản nhất để bạn có thể tự học lập trình web3 Solidity bằng tiếng Việt, tự học online ngôn ngữ lập trình Solidity để Code ra một Smart Contract trên blockchain của ETH. Khoá học này dành cho những lập trình viên Việt Nam nhưng không giỏi đọc các tài liệu bằng tiếng Anh. Đặc biệt, những bài học này sẽ không rườm rà các lý thuyết. Vậy nên những khái niệm như Blockchain là gì, Smart Contract là gì thì mời các bạn tự tra cứu Google :) ĐỐI TƯỢNG PHÙ HỢP Trên cơ sở là bạn cũng đã có kiến thức về các ngôn ngữ lập trình khác rồi, giờ có nhu cầu học thêm một ngôn ngữ mới. Bạn cần một website học lập trình web3 Solidity một cách hệ thống từ A đến Z và bài bản. Còn nếu bạn là một người mới tinh như trang giấy trắng về code, chưa biết tí gì về lập trình thì xin hãy quay lại đây sau. Hãy học một khoá lập trình căn bản trước nhé. THỰC HÀNH CODE Ở ĐÂU? Trong khoá tự học lập trình web3 Solidity này, chúng ta sử dụng trình soạn thảo online là

Bài 1: Tài liệu tự học Solidity. Contracts & Pragma. Hợp Đồng và phiên bản Pragma

Contracts và  Pragma Trong khoá học online miễn phí Tự học lập trình web3 - Tự học ngôn ngữ lập trình Solidity Những chú ý trước khi bắt đầu khoá học được trình bày tại  bài giới thiệu khoá học Summary for English Visiter pragma solidity >=0.5.0 <0.6.0; contract HelloWorld { } Thank you! 1. Contract Mã của Solidity được gói gọn trong các hợp đồng Contract. Hợp đồng là khối code cơ bản của các ứng dụng Ethereum - tất cả các biến và hàm đều thuộc một hợp đồng và đây sẽ là điểm khởi đầu của tất cả các dự án.  Một hợp đồng trống có tên HelloWorld sẽ trông như thế này: contract HelloWorld { } 2. Phiên bản Pragma Code solidity phải bắt đầu bằng "version pragma" - một khai báo về phiên bản của trình biên dịch Solidity mà mình sử dụng. Điều này là để ngăn chặn các sự cố với các phiên bản trình biên dịch trong tương lai có thể gây ra lỗi với đoạn code của bạn. Ví dụ muốn biên dịch từ 0.5.0 đến 0.6.0 thì  bạn khai báo trên cùng như sau:  pragma solidity >=0.5.0 <0.6.0;

Tự học chơi đàn Kalimba. Chơi Kalimba bắt đầu từ đâu?

Tự học chơi đàn Kalimba. Chơi Kalimba bắt đầu từ đâu? iOS:  https://apps.apple.com/vn/app/kalimba-app-with-songs-numbers/id6473744011 Android:  https://play.google.com/store/apps/details?id=ss.kalimba.with.numbers.songs Các bạn có thể xem lại bài giới thiệu về đàn Kalimba tại đây Kalimba là một nhạc cụ phổ biến trong giới trẻ hiện nay nhưng không phải ai cũng biết cách tự học kalimba một cách dễ dàng được đúng không? Đừng lo, Kalimba thực sự là một nhạc cụ chơi cực kì cực kì đơn giản mà không hề tốn quá nhiều công sức đâu nè. Guitar Station sẽ hướng dẫn bạn cách tự học chơi đàn Kalimba thật đơn giản nhé! Kalimba chơi phổ biến bằng cách dùng 2 ngón tay cái gảy vào các phím để phát ra thành tiếng. Vậy phải gảy như thế nào mới đúng? Bạn đừng lo, muốn biết gảy như thế nào thì bạn phải biết được thể loại nhạc bạn muốn chơi đã nha. Chơi Kalimba cũng giống các nhạc cụ khác, có 2 dạng chơi:  Đệm hát: vừa đàn vừa hát. Solo: đánh nốt nguyên bài. Kalimba là dạng piano đơn giản nên thường sẽ thiên