Rainbow logo
RainbowKit
2.2.10

模态钩子

模态钩子

通过 Hooks 编程式打开模态

提供以下钩子以允许在您的应用程序中任何地方编程式地打开模态。

  • useConnectModal
  • useAccountModal
  • useChainModal

每个钩子返回一个包含打开其相应模态功能的对象。请注意,如果您的应用程序未处于模态可以打开的所需状态,则返回的函数将是未定义的。

import { useConnectModal, useAccountModal, useChainModal, } from '@rainbow-me/rainbowkit';
export const YourApp = () => {
const { openConnectModal } = useConnectModal();
const { openAccountModal } = useAccountModal();
const { openChainModal } = useChainModal();
return (
<>
{openConnectModal && (
<button onClick={openConnectModal} type="button">
Open Connect Modal
</button>
)}
{openAccountModal && (
<button onClick={openAccountModal} type="button">
Open Account Modal
</button>
)}
{openChainModal && (
<button onClick={openChainModal} type="button">
Open Chain Modal
</button>
)}
</>
);
};

每个钩子还返回一个表示模态状态的布尔值。通常建议您完全依赖 Wagmi 钩子(例如 useAccount)来直接响应用户钱包连接状态,而不是依赖于连接模态的状态。

const { connectModalOpen } = useConnectModal();
const { accountModalOpen } = useAccountModal();
const { chainModalOpen } = useChainModal();

RainbowKit 设计为非打扰性和响应性,因此 dApp 无论用户是否已连接钱包都应始终呈现用户界面。用户可以直接从 MetaMask 连接或断开其钱包,因此 dApp 必须对底层连接状态直接作出响应。

依赖于以太坊身份验证机制进行用户验证的 dApp 应当改为依赖于 认证 功能。