使用WalletConnect Web3Modal v3 链接钱包基础教程

我使用的是vue+ethers@5.7.2

官方文档:WalletConnect

1.安装

yarn add @web3modal/ethers5 ethers@5.7.2
或者
npm install @web3modal/ethers5 ethers@5.7.2

2.引用
新建一个js文件,在main.js中引入,初始化配置sdk


import {
  createWeb3Modal,
  defaultConfig,
} from "@web3modal/ethers5/vue";

// 1. Get projectId
const projectId = import.meta.env.VITE_PROJECT_ID;

// 2. Set chains
const mainnet = {
  chainId: 1,
  name: 'Ethereum',
  currency: 'ETH',
  explorerUrl: 'https://etherscan.io',
  rpcUrl: 'https://cloudflare-eth.com'
};

// 3. Create modal
const metadata = {
  name: 'My Website',
  description: 'My Website description',
  url: 'https://mywebsite.com',
  icons: ['https://avatars.mywebsite.com/']
}

createWeb3Modal({
  ethersConfig: defaultConfig({ metadata }),
  chains: [mainnet],
  projectId
})

获取 address chainId isConnected相关信息


import { useWeb3ModalAccount } from "@web3modal/ethers5/vue";

// 一定要先初始化完成才能调用获取到
const { address, chainId, isConnected } = useWeb3ModalAccount();

const getWalletInfo = () => {
	console.log({
		address,
		chainId,
		isConnected
	})
	// 获取更改后的相关操作....
};



// 这里可以使用 watch 监听钱包变化
watch(
  () => address.value,
  () => {
    getWalletInfo();
  }
);

调用签名


import { useWeb3ModalSigner } from "@web3modal/ethers5/vue";

// 一定要先初始化完成才能调用获取到
const { signer } = useWeb3ModalSigner();

const onSignMessage = async ()=> {
  try {
    const signature = await signer.value.signMessage("Hello Web3Modal Ethers");
    console.log('签名信息',signature);
  } catch (error) {
    console.log("签名失败", error);
  }
}

以上调用方法可以自己结合使用, 具体可以参考官方文档

3.网络组件 点这里看文档

初始化引用之后再调用

<w3m-button />
<w3m-account-button />
<w3m-connect-button />
<w3m-network-button />

在这里插入图片描述

4.自定义组合 点这里看文档


<script setup>
import { useWeb3Modal } from "@web3modal/ethers5/vue";
const { open } = useWeb3Modal();
</script>

<van-button round type="primary" @click="open()">
	<span v-if="userStore.address !== ''">
	   {{ userStore.address) }}
	 </span>
	 <span v-else>Connect Wallet</span>
</van-button>

结尾
projectId 可以到 WalletConnect Cloud 进行注册创建

页面调用效果图 官方示例
在这里插入图片描述
在这里插入图片描述

  • 11
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
可能是因为 resetFields 方法默认只会重置被绑定的表单域,而 modal 中的表单域没有被直接绑定到 Form 上,所以 resetFields 方法无法重置它们。 可以尝试在 modal 的关闭事件中手动调用 resetFields 方法,例如: ```html <template> <div> <a-button @click="showModal">打开 Modal</a-button> <a-modal v-model:visible="visible" @cancel="handleCancel" @ok="handleOk"> <a-form :form="form"> <a-form-item label="姓名" name="name"> <a-input v-model:value="form.name" /> </a-form-item> <a-form-item label="年龄" name="age"> <a-input-number v-model:value="form.age" /> </a-form-item> </a-form> </a-modal> </div> </template> <script> import { defineComponent } from 'vue'; import { Modal, Form, Input, InputNumber } from 'ant-design-vue'; export default defineComponent({ components: { 'a-modal': Modal, 'a-form': Form, 'a-input': Input, 'a-input-number': InputNumber, }, data() { return { visible: false, form: {}, }; }, methods: { showModal() { this.visible = true; }, handleCancel() { this.visible = false; }, handleOk() { this.$refs.form.validate((valid) => { if (valid) { // 提交表单 this.visible = false; } }); }, resetForm() { this.$refs.form.resetFields(); }, }, watch: { visible(visible) { if (!visible) { this.resetForm(); } }, }, }); </script> ``` 在上面的代码中,当 modal 关闭时会调用 `resetForm` 方法手动重置表单域。另外,为了获取 Form 实例,还需要给 Form 组件添加一个 ref 属性,例如 `ref="form"`。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值