wallet connect简单使用

wallet connect简单使用

准备工作

新建一个文件夹xxx
右键在终端中打开

npm init -y

在文件夹中新建src目录
在src目录中新建index.html和index.js文件
目录大概就这样我这是打包过的
在这里插入图片描述

安装

按照官方文档先安装
官方页面长这样
我们需要用到的是web3Modal
在这里插入图片描述
点进去我们可以看到两个选项,我这边用的是第二个
在这里插入图片描述
点进去复制命令并运行

npm install @web3modal/ethereum @web3modal/html @wagmi/core v

配置

安装完成以后在index.js中添加以下代码

import { EthereumClient, w3mConnectors, w3mProvider } from '@web3modal/ethereum'
import { Web3Modal } from '@web3modal/html'
import { configureChains, createConfig } from '@wagmi/core'
import {bsc,arbitrum, mainnet, polygon } from '@wagmi/core/chains'

const chains = [bsc,mainnet, polygon,arbitrum]
const projectId = 'db7b6ce8400c28046ecf596904518647'

const { publicClient } = configureChains(chains, [w3mProvider({ projectId })])
const wagmiConfig = createConfig({
  autoConnect: true,
  connectors: w3mConnectors({ projectId, chains }),
  publicClient
})
const ethereumClient = new EthereumClient(wagmiConfig, chains)
const web3modal = new Web3Modal({ projectId }, ethereumClient)


console.log(ethereumClient.getNetwork())
console.log(ethereumClient.getAccount());

这段代码官网上也有,只是我们需要配置自己的projectId ,以及配置公链,支持的公链可以在\node_modules\viem\chains下查看

const chains = [bsc,mainnet, polygon,arbitrum]

公链配置哪个写在前面哪个就是默认连接的公链
projectId 要自己申请
在这个地方点进去直接申请就可以
在这里插入图片描述
在index.html中添加一个按钮

<w3m-core-button></w3m-core-button>

这个也还是官方文档上有

打包

做完上面的配置我们需要用webpack打包项目
如果没有打包我们直接打开的话我们会报如下的错误
在这里插入图片描述
打包命令

npx webpack build

没有安装webpack的需要自己安装,我直接使用是因为我全局安装过

npm insatll webpack -g

打包完成后会在文件夹中多出一个dist文件夹,里面会有个main.js文件
在html中引入main.js

测试

打开html文件
不出意外应该会有这么一个按钮
在这里插入图片描述
点击按钮就可以显示二维码了
当然我下面这个二维码是本地测试用的
扫了没用
在这里插入图片描述

可以扫码连接或者直接点下面的小图标用浏览器插件连接
连接成功
在这里插入图片描述
要退出或者切换公链只需在次点击按钮即可
在这里插入图片描述
完结

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

crypto_犀牛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值