ether.js中调用连接metamask钱包并获取当前钱包地址、余额、链ID、链名称的代码实现

  • A+
所属分类:以太坊ETH

chatGPT账号

ether.js中调用连接metamask钱包并获取当前钱包地址、余额、链ID、链名称的代码实现

在ether.js类库中通过js调用metamask钱包连接当前dapp,并且获取当前连接的钱包地址,钱包持有的ETH余额、当前连接的公链链ID,链名称的代码实现如下。通过如下代码可以唤起metamask钱包,对发起的交易hash进行签名,执行链上的交易。

/*判断是否按照metamask钱包-begin-*/
        if (typeof window.ethereum === "undefined") {
          alert("please install metamask first!");
          return;
        }
        /*判断是否按照metamask钱包-end-*/

        /*连接钱包获取钱包地址和余额-begin-*/
        let accounts = await window.ethereum.request({method:'eth_requestAccounts'});
        if (accounts.length > 0 ) {
          document.getElementById("wallet-address").innerText = accounts[0];
          document.getElementById("wallet-address").style.textAlign = 'left'; // 添加左对齐样式

          // 创建一个以太坊 provider 对象
          const provider = new ethers.providers.Web3Provider(window.ethereum);
          // 获取余额(单位为 wei)
          const balance = await provider.getBalance(accounts[0]);
          // 将余额转换成以太(单位为 ether)
          const etherBalance = ethers.utils.formatEther(balance);
          // 输出余额(单位为 ether)
          //console.log(`Address ${accounts[0]} has a balance of ${etherBalance} ether.`);

调用metamask钱包完成交易hash的签名后,触发执行链上合约,完成dapp的功能模块。

在连接钱包中不能存在await方法,比如获取合约名称 await contract.name(); 该操作会导致唤起metamask钱包失效,一直处于等待状态。

pdf+视频Arbitrum链发币教程及多模式组合合约源代码下载:

Arbitrum链发币(合约部署、开源、锁仓、LP、参数配置、开发、故障处理、工具使用)教程下载:

ether.js中调用连接metamask钱包并获取当前钱包地址、余额、链ID、链名称的代码实现

多模式(燃烧、回流指定营销地址、分红本币及任意币种,邀请推广八代收益,LP加池分红、交易分红、复利分红、NFT分红、自动筑池、动态手续费、定时开盘、回购)组合合约源代码下载:

ether.js中调用连接metamask钱包并获取当前钱包地址、余额、链ID、链名称的代码实现ether.js中调用连接metamask钱包并获取当前钱包地址、余额、链ID、链名称的代码实现

pdf+视频Arbitrum链发币教程及多模式组合合约源代码下载地址:

此处为隐藏的内容!
登录后才能查看!

添加VX或者telegram获取全程线上免费指导

ether.js中调用连接metamask钱包并获取当前钱包地址、余额、链ID、链名称的代码实现

免责声明

发文时比特币价格:$27249

当前比特币价格:[crypto coins=”BTC” type=”text” show=”price”]

当前比特币涨幅:[crypto coins=”BTC” type=”text” show=”percent”]

免责声明:

本文不代表路远网立场,且不构成投资建议,请谨慎对待。用户由此造成的损失由用户自行承担,与路远网没有任何关系;

路远网不对网站所发布内容的准确性,真实性等任何方面做任何形式的承诺和保障;

网站内所有涉及到的区块链(衍生)项目,路远网对项目的真实性,准确性等任何方面均不做任何形式的承诺和保障;

网站内所有涉及到的区块链(衍生)项目,路远网不对其构成任何投资建议,用户由此造成的损失由用户自行承担,与路远网没有任何关系;

路远区块链研究院声明:路远区块链研究院内容由路远网发布,部分来源于互联网和行业分析师投稿收录,内容为路远区块链研究院加盟专职分析师独立观点,不代表路远网立场。

 

 

本文是全系列中第223 / 247篇:行业技术

  • 我的微信
  • 这是我的微信扫一扫
  • weinxin
  • 我的电报
  • 这是我的电报扫一扫
  • weinxin
chatGPT账号
路远

发表评论

您必须登录才能发表评论!