如何使用 web3modal 获取已连接钱包的地址?

ste*_*ste 5 javascript reactjs next.js web3js

我正在使用 next.js 和 web3 构建一个应用程序。要将用户钱包连接到前端,我使用 web3modal,如下所示:

const Home: NextPage = () => {
  const [signer, setSigner] = useState<JsonRpcSigner | null>(null)

  async function connect() {
    const web3Modal = new Web3Modal()
    const connection = await web3Modal.connect()
    const provider = new ethers.providers.Web3Provider(connection)
    const signer = provider.getSigner()

    setSigner(signer)
  }

  return (
    <div className="flex justify-center">
      <button onClick={() => connect()}>Connect wallet</button>
      { signer && (
        <h3>wallet connected: {signer._address}</h3>
      )}
    </div>
  )
}
Run Code Online (Sandbox Code Playgroud)

用户可以成功连接钱包,遗憾的signer._address是始终为null。我想向用户显示刚刚连接的地址,我该如何解决这个问题?

Dyl*_*ler 5

这不是关于 web3Modal 的问题,而是关于 ethers 的问题。

你可以这样获取地址:

const [address, setAddress] = useState()
// ...
setAddress(await signer.getAddress())
Run Code Online (Sandbox Code Playgroud)

文档位于: https: //docs.ethers.io/v5/api/signer/#Signer-getaddress