未捕获的 ReferenceError:web3 未在 window.onload 中定义
2017-01-01
6268
我正在尝试让我的第一个 dapp 运行;我知道我已经很接近了,但一直遇到 web3 问题。
我正在 Windows 10 上工作,通过 PowerShell 运行 testrpc 节点。我使用 truffle 设置我的文件夹和示例文件,然后编译和迁移。
我认为我没有更改由 truffle 构建的 app.js 文件中的任何内容……这是代码:
var accounts;
var account;
function setStatus(message) {
var status = document.getElementById("status");
status.innerHTML = message;
};
function refreshBalance() {
var meta = MetaCoin.deployed();
meta.getBalance.call(account, {from: account}).then(function(value) {
var balance_element = document.getElementById("balance");
balance_element.innerHTML = value.valueOf();
}).catch(function(e) {
console.log(e);
setStatus("Error getting balance; see log.");
});
};
function calcPremium() {
var premium = parseInt(document.getElementById("benefit").value)/10000;
document.getElementById("monthlyPremium").innerHTML = " Monthly Premium: $"+premium.toFixed(2);
};
function sendCoin() {
var meta = MetaCoin.deployed();
var amount = parseInt(document.getElementById("monthlyPremium").value);
var receiver = document.getElementById("receiver").value;
setStatus("Initiating transaction... (please wait)");
meta.sendCoin(receiver, amount, {from: account}).then(function() {
setStatus("Transaction complete!");
refreshBalance();
}).catch(function(e) {
console.log(e);
setStatus("Error sending coin; see log.");
});
};
window.onload = function() {
web3.eth.getAccounts(function(err, accs) {
if (err != null) {
alert("There was an error fetching your accounts.");
return;
}
if (accs.length == 0) {
alert("Couldn't get any accounts! Make sure your Ethereum client is configured correctly.");
return;
}
accounts = accs;
account = accounts[0];
refreshBalance();
});
}
我能够在 Chrome 浏览器中打开 html 文件,并启用 MetaMask 插件。但是,由于 web3 错误问题,我似乎无法以任何方式与合约进行交互。确切的信息是这篇文章的主题行。
提前感谢任何帮助或指导!
1个回答
您能否尝试一下并查看。我认为 onload 是导致问题的原因。
$(window).load function() {
web3.eth.getAccounts(function(err,accs) {
if (err != null) {
alert("There was an error fetching your accounts.");
return;
}
if (accs.length == 0) {
alert("Couldn't get any accounts! Make sure your Ethereum client is configured correctly.");
return;
}
accounts = accs;
account = accounts[0];
refreshBalance();
});
}
Ranadip Dutta
2017-01-02