【问题标题】:How to put two function calls in a HTML file?如何将两个函数调用放在一个 HTML 文件中?
【发布时间】:2017-09-05 12:42:08
【问题描述】:

我正在学习 Solidity(用于智能合约),现在需要设计一个 UI 来与部署合约交互。

注意:如果问题与本论坛无关,请告诉我(而不是投反对票),我会将其删除。


我的 HTML 和 .js 文件如下。问题是,当我在 .js 文件中同时包含“distribute()”和“update_exchange_rate()”函数时,我的 HTML 文件将无法工作。但如果我从 .js 文件中删除它们中的任何一个,我不会有任何问题。

问题:为什么我会遇到这个问题?如何解决上述问题?我可以在 window.app 中有多个函数(定义)吗?


编辑:如果我将这两个函数都放在 .js 文件中,我也会收到 webpack 错误。但是如果我删除其中一个功能,错误就会消失。


<!DOCTYPE html>
<html>
<head> 
<script src="./app.js"></script>
</head>
<body>
<h1>MetaCoin</h1>
<h2>Example Truffle Dapp</h2>
<br>
<br><label for="amountB">Exchange rate:</label><input type="text" 
id="amountA" placeholder="e.g., 95"></input>
<br><label for="receiverA">ReceiverA:</label><input type="text" 
id="receiverA" placeholder="e.g., 95"></input>
<br><label for="receiverB">ReceiverB:</label><input type="text" 
id="receiverB" placeholder="e.g., 95"></input>
<br><br><button id="send1" onclick="App.distribute()">Send 
MetaCoin</button>
<br><br>
<br><label for="amountB">Exchange rate:</label><input type="text" 
id="amountB" placeholder="e.g., 95"></input>
<br><br><button id="send2" 
onclick="App.update_exchange_Rate()">update_exchange_Rate</button>
<br><br>
<br>
</body>
</html>

我的js文件是:

  import "../stylesheets/app.css";
  import { default as Web3} from 'web3';
   import { default as contract } from 'truffle-contract'
  import metacoin_artifacts from '../../build/contracts/MetaCo.json'

  var MetaCo = contract(metacoin_artifacts);
  var accounts;
  var account;
  window.App = {
  start: function() {
  MetaCo.setProvider(web3.currentProvider);
  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];
 });
},
setStatus: function(message) {
var status = document.getElementById("status");
status.innerHTML = message;
},


distribute: function() { // XXX Here is where the problem occures!
var amountA = parseInt(document.getElementById("amountA").value);
var receiver1= document.getElementById("receiverA").value;
var receiver2 = document.getElementById("receiverB").value;
var meta;
MetaCo.deployed().then(function(instance2) {
  meta = instance2;
return meta.distribute(receiver1,receiver2, amountA,{from: account});
})
}

 update_exchange_Rate: function() { // XXX Here is where the problem occures!
  var amountB = parseInt(document.getElementById("amountB").value);
 var meta1;
 MetaCo.deployed().then(function(instance3) {
  meta1 = instance3;
return meta1.update_exchange_Rate(amountB,{from: account});
})
 }
};

window.addEventListener('load', function() {
if (typeof web3 !== 'undefined') {
console.warn("Using web3 detected from external source. If you find 
that your accounts don't appear or you have 0 MetaCoin, ensure you've 
configured that source properly. If using MetaMask, see the following 
link. 
Feel free to delete this warning. :) 
http://truffleframework.com/tutorials/truffle-and-metamask")
// Use Mist/MetaMask's provider
 window.web3 = new Web3(web3.currentProvider);
 } else {
console.warn("No web3 detected. Falling back to http://localhost:8545. 
You should remove this fallback when you deploy live, as it's 
inherently 
insecure. Consider switching to Metamask for development. More info 
here: 
http://truffleframework.com/tutorials/truffle-and-metamask");
// fallback - use your fallback strategy (local node / hosted node + 
in-dapp id mgmt / fail)
window.web3 = new Web3(new 
Web3.providers.HttpProvider("http://localhost:8545"));
  }

App.start();
});

【问题讨论】:

    标签: javascript html webpack


    【解决方案1】:

    我们只拿这个按钮,另一个有完全相同的问题......

    <button id="send2" onclick="App.update_exchange_Rate()">update_exchange_Rate</button>
    

    onclick 属性期望接收一个函数。然后在每次点击时调用该函数。但是函数本身并不返回函数...

    App.update_exchange_Rate() 将在浏览器看到该部分后立即执行,并使用它的返回值。但这不是我们想要的!我们希望执行该函数......所以我们需要给出函数,而不是对属性的调用,如下所示:

    <button id="send2" onclick="App.update_exchange_Rate">update_exchange_Rate</button>
    

    <button id="send2" onclick="function(){App.update_exchange_Rate();}">update_exchange_Rate</button>
    

    现在,如果您这样做,您肯定会落入一个出乎意料的范围内。您没有在函数中使用this,因此我将跳过该范围界定部分,如果需要,您可以稍后阅读。

    【讨论】:

    • 感谢您的回答。我尝试了您的建议,但如果我从 App.update_exchange_Rate() 或 App.distribute() 中删除“()”,它将无法运行。
    • 我添加了另一种可能性。绘制 HTML 时必须声明对象和函数,但情况可能并非如此。使用匿名函数将绕过这一点。
    • 谢谢,我也试过了。请您看一下我刚刚添加的“编辑”部分。
    • 你在两个函数定义之间缺少一个冒号,这肯定是 webpack 给你的错误。
    • 是的,已排序。感谢您的cmets和回答。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-12-25
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2023-02-11
    • 1970-01-01
    相关资源
    最近更新 更多