Beitrag
Teile dein Wissen.

So integrieren Sie das Vue-Frontend-Framework in das Sui-Ökosystem
Ich arbeite derzeit an der Transformation eines alten Frontend-Projekts. Das alte Projekt verwendet Vue als Frontend-Framework. Wie man sich mit der Wallet des Sui-Ökosystems verbindet, hat mir schon immer Kopfschmerzen bereitet. In der vorherigen Entwicklung konnte ich, wenn ich das React-Framework verwendet hätte, problemlos das offizielle @mysten /dapp-kit verwenden, um einen kompletten Satz von Wallet-Verbindungen aufzubauen, Transaktionen zu initiieren und Methoden zu signieren.
Zu den von Mysten Labs bereitgestellten Methoden gehört @mysten/wallet-standard
diese Bibliothek, mit der die @mysten/suican
entsprechenden Methoden für Wallet-Verbindungs- und Signaturtransaktionen erstellt werden können.
Das Herstellen einer Verbindung zur Wallet läuft wie folgt ab:
Stellen Sie fest, ob der Benutzer eine Verbindung zur Wallet hergestellt hat:
initWallet() {
const connectedWallet = window.localStorage.getItem("connectedWallet")
const connectedAddress = window.localStorage.getItem("connectedAddress")
if (connectedWallet && this.supportWallets.includes(connectedWallet) && connectedAddress) {
this.connectWallet(connectedWallet)
}
}
Verbinde deine Wallet
// Connect Wallet (e.g., Slush)
async connectWallet(walletName) {
try {
const availableWallets = getWallets().get();
let wallet = availableWallets.find(e => e.name === walletName);
await wallet.features['standard:connect'].connect();
if (wallet.accounts.length > 0) {
// Usually the first account is the currently active address
const address = wallet.accounts[0].address;
this.connectedWallet = wallet.name;
this.address = address;
window.localStorage.setItem("connectedAddress", address);
window.localStorage.setItem("connectedWallet", wallet.name);
}
// Listen for wallet address changes or disconnection
wallet.features['standard:events'].on('change', (event) => {
// Logic for when the current wallet address doesn't match the stored address or when disconnected
if (event.accounts.length === 0 || event.accounts[0].address !== this.address) {
console.log('User changed accounts or disconnected...');
setTimeout(() => {
window.localStorage.removeItem("connectedAddress");
window.localStorage.removeItem("connectedWallet");
window.location.reload();
}, 1000);
}
});
} catch (error) {
console.log(error);
}
}
Das Folgende ist der Übertragungsvorgang. Alle Transaktionen können wallet.features ['sui:signTransaction'] .signTransactionSigned sein:
async transferSui() {
try {
const wallet = getWallets().get().find(e => e.name === this.connectedWallet)
const amount = this.amount
const toAddress = this.toAddress
const tx = new Transaction()
const [coin] = tx.splitCoins(tx.gas, [amount * 1e9])
tx.transferObjects([coin], toAddress)
const { bytes, signature } = await wallet.features['sui:signTransaction'].signTransaction({
transaction: tx,
account: wallet.accounts[0],
chain: `sui:${import.meta.env.VITE_SUPPORT_NETWORK}`
});
const executeRes = await suiClient.executeTransactionBlock({
transactionBlock: bytes,
signature: signature,
options: {
showEffects: true,
showObjectChanges: true,
showBalanceChanges: true,
showEvents: true,
showInput: true
}
});
this.hash = executeRes.digest
} catch (error) {
console.log(error);
}
}
Schließlich können Sie eine Funktion erstellen, um die Wallet im Web zu trennen:
async disconnectWallet() {
try {
const availableWallets = getWallets().get();
const walletName = window.localStorage.getItem("connectedWallet")
let wallet = availableWallets.find(e => e.name === walletName)
await wallet.features['standard:disconnect'].disconnect();
window.localStorage.removeItem("connectedAddress")
window.localStorage.removeItem("connectedWallet")
window.location.reload()
} catch (error) {
console.log('meet some errors ');
}
},
- Sui
- SDKs and Developer Tools
wie stehts mit anderen?
Sui is a Layer 1 protocol blockchain designed as the first internet-scale programmable blockchain platform.
Verdiene deinen Anteil an 1000 Sui
Sammle Reputationspunkte und erhalte Belohnungen für deine Hilfe beim Wachstum der Sui-Community.
- Warum benötigt BCS eine genaue Feldreihenfolge für die Deserialisierung, wenn Move-Strukturen benannte Felder haben?53
- Fehler bei der Überprüfung mehrerer Quellen“ in den Veröffentlichungen des Sui Move-Moduls — Automatisierte Fehlerbehebung42
- Sui-Transaktion schlägt fehl: Objekte sind für eine andere Transaktion reserviert24
- Wie interagieren Fähigkeitsbeschränkungen mit dynamischen Feldern in heterogenen Sammlungen?04