好的,以下是一个简单的前端web3应用程序,用于与上面编写的ERC20智能合约交互:
```html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Web3 App</title>
<script src="https://cdn.jsdelivr.net/npm/web3@1.3.5/dist/web3.min.js"></script>
</head>
<body>
<h1>Web3 App</h1>
<p>Account: <span id="account"></span></p>
<p>Balance: <span id="balance"></span> ERC20 tokens</p>
<input id="to" type="text" placeholder="Recipient address">
<input id="value" type="text" placeholder="Amount">
<button onclick="transfer()">Transfer</button>
<script>
window.addEventListener('load', async () => {
if (typeof window.ethereum !== 'undefined') {
await window.ethereum.enable();
const web3 = new Web3(window.ethereum);
const contractAddress = 'CONTRACT_ADDRESS';
const contractAbi = [{
'constant': true,
'inputs': [{'name': '', 'type': 'address'}],
'name': 'balanceOf',
'outputs': [{'name': '', 'type': 'uint256'}],
'payable': false,
'stateMutability': 'view',
'type': 'function'
}, {
'constant': true,
'inputs': [],
'name': 'name',
'outputs': [{'name': '', 'type': 'string'}],
'payable': false,
'stateMutability': 'view',
'type': 'function'
}, {
'constant': false,
'inputs': [{'name': '_to', 'type': 'address'}, {'name': '_value', 'type': 'uint256'}],
'name': 'transfer',
'outputs': [{'name': 'success', 'type': 'bool'}],
'payable': false,
'stateMutability': 'nonpayable',
'type': 'function'
}, {
'constant': true,
'inputs': [],
'name': 'symbol',
'outputs': [{'name': '', 'type': 'string'}],
'payable': false,
'stateMutability': 'view',
'type': 'function'
}, {
'constant': false,
'inputs': [{'name': '_spender', 'type': 'address'}, {'name': '_value', 'type': 'uint256'}],
'name': 'approve',
'outputs': [{'name': 'success', 'type': 'bool'}],
'payable': false,
'stateMutability': 'nonpayable',
'type': 'function'
}, {
'constant': true,
'inputs': [{'name': '', 'type': 'address'}, {'name': '', 'type': 'address'}],
'name': 'allowance',
'outputs': [{'name': '', 'type': 'uint256'}],
'payable': false,
'stateMutability': 'view',
'type': 'function'
}, {
'constant': false,
'inputs': [{'name': '_from', 'type': 'address'}, {'name': '_to', 'type': 'address'}, {
'name': '_value',
'type': 'uint256'
}],
'name': 'transferFrom',
'outputs': [{'name': 'success', 'type': 'bool'}],
'payable': false,
'stateMutability': 'nonpayable',
'type': 'function'
}, {
'inputs': [{'name': '_name', 'type': 'string'}, {'name': '_symbol', 'type': 'string'}, {
'name': '_totalSupply',
'type': 'uint256'
}],
'payable': false,
'stateMutability': 'nonpayable',
'type': 'constructor'
}, {
'anonymous': false,
'inputs': [{'indexed': true, 'name': '_from', 'type': 'address'}, {
'indexed': true,
'name': '_to',
'type': 'address'
}, {'indexed': false, 'name': '_value', 'type': 'uint256'}],
'name': 'Transfer',
'type': 'event'
}, {
'anonymous': false,
'inputs': [{'indexed': true, 'name': '_owner', 'type': 'address'}, {
'indexed': true,
'name': '_spender',
'type': 'address'
}, {'indexed': false, 'name': '_value', 'type': 'uint256'}],
'name': 'Approval',
'type': 'event'
}];
const contract = new web3.eth.Contract(contractAbi, contractAddress);
const accounts = await web3.eth.getAccounts();
const account = accounts[0];
document.getElementById('account').textContent = account;
const balance = await contract.methods.balanceOf(account).call();
document.getElementById('balance').textContent = balance;
transfer = async () => {
const to = document.getElementById('to').value;
const value = document.getElementById('value').value;
await contract.methods.transfer(to, value).send({from: account});
location.reload();
};
} else {
alert('Please install MetaMask to use this dApp!');
}
});
</script>
</body>
</html>
```
在这个应用程序中,我们使用了web3.js库来与以太坊网络交互,首先需要检查MetaMask是否已安装并启用。然后,我们使用智能合约地址和ABI创建了一个智能合约实例,以便可以与合约交互。我们还获取了当前用户的帐户和智能合约中该帐户的余额,并将其显示在页面上。最后,我们定义了一个转移函数,该函数在用户输入收件人地址和金额后,调用智能合约的“transfer”函数来发送代币,并重新加载页面以更新余额。
请注意,在这个示例中,你需要将“CONTRACT_ADDRESS”替换为你部署的ERC20智能合约的地址。