forked from WTFAcademy/WTF-Dapp
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request WTFAcademy#3 from WTFAcademy/feat/connect
feat: init connect wallet
- Loading branch information
Showing
2 changed files
with
58 additions
and
1 deletion.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,60 @@ | ||
连接钱包是 DApp 中最重要的交互,这一讲我们会引导你通过 [wagmi](https://wagmi.sh) 和 [Ant Design Web3](https://web3.ant.design) 来实现连接钱包的功能。 | ||
|
||
> 文档编写中,敬请期待。 | ||
## DApp 如何连接钱包 | ||
|
||
在 DApp 中,我们需要连接钱包来获取用户的钱包地址,以及进行一些需要用户签名的操作,比如发送交易、签名消息等。连接钱包有多种方式,通常在以太坊中有如下三种方式: | ||
|
||
- 通过浏览器插件建立连接。 | ||
- 通过在钱包 App 中访问 DApp 建立连接。 | ||
- 通过 WalletConnect 协议建立连接。 | ||
|
||
其中前面两种对于 DApp 来说都是通过钱包注入到浏览器运行环境中的接口来实现的,而 WalletConnect 则是通过服务端中转的方式来实现的。而钱包注入接口也有两种方式,一种是通过 [EIP-1193](https://eips.ethereum.org/EIPS/eip-1193) 来实现的,另一种是通过 [EIP-6963](https://eips.ethereum.org/EIPS/eip-696) 来实现的。EIP-1193 是一个早期的协议,也比较简单,接下来我们先尝试用这种方式来和钱包建立连接。 | ||
|
||
## 配置钱包 | ||
|
||
我们以 [MetaMask](https://metamask.io/) 为例,看一下如何和 MetaMask 钱包建立连接。 | ||
|
||
```diff | ||
|
||
import { createConfig, http } from "wagmi"; | ||
import { mainnet } from "wagmi/chains"; | ||
- import { WagmiWeb3ConfigProvider } from "@ant-design/web3-wagmi"; | ||
+ import { WagmiWeb3ConfigProvider, MetaMask } from "@ant-design/web3-wagmi"; | ||
- import { Address, NFTCard } from "@ant-design/web3"; | ||
+ import { Address, NFTCard, Connector, ConnectButton } from "@ant-design/web3"; | ||
+ import { injected } from "wagmi/connectors"; | ||
|
||
const config = createConfig({ | ||
chains: [mainnet], | ||
transports: { | ||
[mainnet.id]: http(), | ||
}, | ||
+ connectors: [ | ||
+ injected({ | ||
+ target: "metaMask", | ||
+ }), | ||
+ ], | ||
}); | ||
|
||
export default function Web3() { | ||
return ( | ||
- <WagmiWeb3ConfigProvider config={config}> | ||
+ <WagmiWeb3ConfigProvider config={config} wallets={[MetaMask()]}> | ||
<Address format address="0xEcd0D12E21805803f70de03B72B1C162dB0898d9" /> | ||
<NFTCard | ||
address="0xEcd0D12E21805803f70de03B72B1C162dB0898d9" | ||
tokenId={641} | ||
/> | ||
+ <Connector> | ||
+ <ConnectButton /> | ||
+ </Connector> | ||
</WagmiWeb3ConfigProvider> | ||
); | ||
}; | ||
|
||
|
||
``` | ||
|
||
可以得到如下的效果: | ||
|
||
data:image/s3,"s3://crabby-images/52ddb/52ddb7bfad2c077ff95a8d575e0481a08443cb4b" alt="" |