- イベントリスナーの設定: Metamaskは、ウォレットのアカウントが変更されたときに特定のイベントを発行します。ウェブページ上でMetamaskのイベントリスナーを設定することで、アカウントの変更を検出できます。
以下は、JavaScriptを使用してMetamaskのイベントリスナーを設定する例です。
ethereum.on('accountsChanged', function (accounts) {
// アカウントが変更されたときの処理
console.log('新しいアカウント:', accounts[0]);
});
上記のコードでは、accountsChanged
イベントが発生したときに、コンソールに新しいアカウントを出力しています。
- ウォレットの初期化時にアカウントを取得: Metamaskを初期化するときに、現在のアカウントを取得することもできます。これにより、ウォレットの起動時にアカウントが変更されているかどうかを確認できます。
以下は、Metamaskの初期化時に現在のアカウントを取得する例です。
window.addEventListener('load', async () => {
// Metamaskのプロバイダーを取得
if (window.ethereum) {
await window.ethereum.request({ method: 'eth_requestAccounts' });
const accounts = await window.ethereum.request({ method: 'eth_accounts' });
// アカウントの処理
console.log('現在のアカウント:', accounts[0]);
} else {
console.log('Metamaskがインストールされていません');
}
});
上記のコードでは、eth_requestAccounts
とeth_accounts
メソッドを使用して、現在のアカウントを取得しています。
これらの方法を使用すると、Metamaskでアカウントの変更を検出することができます。ウェブページ上でアカウントの変更に応じて適切な処理を行うことができます。必要に応じて、ウォレットのアカウントの変更を監視し、ユーザーに通知する機能を追加することもできます。
以上が、Metamaskでアカウントの変更を検出する方法の基本的な手法です。詳細な実装方法や他の関連機能については、Metamaskのドキュメントやウェブ3.0開発のリソースを参照してください。