Dapp开发(二):前端如何使用web3.js

书接上回,我们了解了一些关于web3.0的相关概念,本来开始正式进入Dapp的开发。(ps:本文只适用于小白观看,不敢在经验丰富的大佬面前耍大刀,有不妥之处欢迎指出)

前篇我们已经在浏览器安装了MetaMask这个扩展,在新启的项目中也安装了web3.js这个库,它有很多函数,使用它可以在以太坊生态系统中通过HTTP或IPC与本地或者以太坊远程节点交互,如查看链上信息等,在此过程中使用是的JSON-RPC(一个无状态且轻量级的远程过程调用(RPC)传送协议,其传递内容透过 JSON 为主)。我们使用web3.js来读取和写入以太坊区块链数据。

首先大家可以打开web3.js的英文官网,如果不习惯看英文的宝子可以看web3.js的中文文档,这是GitHub地址

我们在新创的vue项目中,已经引入了web3.js,接下来,我们看看如何使用他进行交互。如官网所言,他分为四大模块,各自的功能主要是:

  • web3-eth 用来与以太坊区块链及合约的交互;
  • web3-shh Whisper 协议相关,进行p2p通信和广播;
  • web3-bzz swarm 协议(去中心化文件存储)相关;
  • web3-utils 包含一些对 DApp 开发者有用的方法。

将web3.js引入后,我们需要先创建一个 web3 的实例,设置一个 provider。 MetaMask 会有提供一个 ethereumProviderweb3.currentProvider 。可以检查 Web3.givenProvider ,如果属性为 null 再连接本地或远程的节点,这样我们就可以开始使用web3.js了,但我们要判断用户是否连接就需要做另外的处理了。

js 复制代码
var web3 = new Web3(Web3.givenProvider || "ws://localhost:8545");

通常情况下,我们会在页面初始化时,使用一个名为 ethereum 的全局对象,判断用户钱包是否已经授权,此全局对象可以用于与用户的以太坊钱包(MetaMask)进行交互。通过这个 ethereum 对象,开发者可以请求用户授权、获取用户账户信息、发送交易等操作。

使用 ethereum 对象的一般流程如下:

1.检查是否存在 window.ethereum:

首先,检查全局作用域中是否存在 window.ethereum 对象。

2.请求授权:

如果 window.ethereum 存在,通过该对象请求用户授权以访问其账户信息和执行交易。

3.连接到以太坊网络:

一旦用户授权,可以使用 ethereum 对象连接到用户所选择的以太坊网络。

4.发送交易:

通过 ethereum.request 方法,就可以向用户请求发送交易或调用智能合约。

简单示例代码:

js 复制代码
// 检查是否存在 ethereum 对象
if (window.ethereum) {
    const ethereum = window.ethereum;

    // 请求用户授权
    ethereum.request({ method: 'eth_requestAccounts' })
        .then((accounts) => {
            const account = accounts[0];
            console.log('已连接到账户:', account);

            // 实例化 Web3 对象
            const web3 = new Web3(ethereum);

            // 现在可以使用 web3 对象进行以太坊操作
            web3.eth.getBalance(account, (error, balance) => {
                if (!error) {
                    console.log('账户余额:', web3.utils.fromWei(balance, 'ether'), 'ETH');
                } else {
                    console.error('获取余额失败:', error);
                }
            });
        })
        .catch((error) => {
            console.error('请求授权失败:', error);
        });
} else {
    console.error('未检测到 ethereum 对象,请确保以太坊钱包已安装并登录。');
}

当用户成功连接后,实例化web3对象,web3.eth.getBalance方法是获取返回地址在指定区块的余额。这里还提到了web3.utils.fromWei这个方法,这个方法接收两个参数,第一个是数量(wei),第二个是需要转换的单位,用于将以太币数量从最小单位(wei)转换为以太币单位(如 ether),反之还有一个相反的方法web3.utils.toWeiweb3.utils.toWei 方法用于将以太币数量从以太币单位(如 ether)转换为最小单位(wei),接收参数一样。

js 复制代码
web3.utils.fromWei('1', 'ether');//"0.000000000000000001"
web3.utils.toWei('1', 'ether');//"1000000000000000000"

以太币单位转换关系:

  • 1 wei = 1 wei
  • 1 Kwei (Kilowei) = 1,000 wei
  • 1 Mwei (Megawei) = 1,000,000 wei = 1,000 Kwei
  • 1 Gwei (Gigawei) = 1,000,000,000 wei = 1,000 Mwei = 1,000 Kwei
  • 1 microether = 1,000,000,000 wei = 1,000 Mwei = 1,000 Kwei = 1 Gwei
  • 1 milliether = 1,000,000,000,000 wei = 1,000 microether = 1,000 Gwei
  • 1 nanoether = 1,000,000,000,000,000 wei = 1,000 milliether = 1,000,000 microether
  • 1 picoether = 1,000,000,000,000,000,000 wei = 1,000 nanoether = 1,000,000 milliether
  • 1 femtoether = 1,000,000,000,000,000,000,000 wei = 1,000 picoether = 1,000,000 nanoether
  • 1 attoweber = 1,000,000,000,000,000,000,000,000 wei = 1,000 femtoether = 1,000,000 picoether
  • 1 ether = 1,000,000,000,000,000,000,000,000 wei = 1,000 attoweber

以上就是web3.js大致的使用过程了,接下来就是如何调用智能合约进行交互了,智能合约大多使用solidity语言来编写的,想了解更多的可以去看看相关的课程。

相关推荐
霸王蟹32 分钟前
React中useState中更新是同步的还是异步的?
前端·javascript·笔记·学习·react.js·前端框架
霸王蟹34 分钟前
React Hooks 必须在组件最顶层调用的原因解析
前端·javascript·笔记·学习·react.js
专注VB编程开发20年41 分钟前
asp.net IHttpHandler 对分块传输编码的支持,IIs web服务器后端技术
服务器·前端·asp.net
爱分享的程序员1 小时前
全栈项目搭建指南:Nuxt.js + Node.js + MongoDB
前端
隐含2 小时前
webpack打包,把png,jpg等文件按照在src目录结构下的存储方式打包出来。解决同一命名的图片资源在打包之后,重复命名的图片就剩下一个图片了。
前端·webpack·node.js
lightYouUp2 小时前
windows系统中下载好node无法使用npm
前端·npm·node.js
Dontla2 小时前
npm cross-env工具包介绍(跨平台环境变量设置工具)
前端·npm·node.js
小妖6662 小时前
vue2 切换主题色以及单页面好使方法
前端·vue.js·elementui
胡桃夹夹子2 小时前
【前端优化】vue2 webpack4项目升级webpack5,大大提升运行速度
前端·javascript·vue.js·webpack·性能优化
Stringzhua2 小时前
JavaScript【7】BOM模型
开发语言·前端·javascript