javascript - React、Solidity、以太坊:我无法创建正确调用智能合约功能的 React 按钮
问题描述
因此,我目前正在开发 dApp 的后端和前端。
后端是我用 Solidity 编写的智能合约,当我在 Truffle 上使用和测试它时,它运行得非常好。我创建了一个结构,在合同中我使用了这个结构的列表。
struct Offre {
address manager;
string content;
uint number;
}
Offre[] public offres;
我的一个函数返回此列表中任何给定元素的内容。
function getOfferNumber(uint i) public view returns (string r) {
return offres[i].content;
}
所以,我已经在 Truffle 中测试了这个函数,正如预期的那样,它返回了我希望它返回的字符串。
现在,我正在尝试在 React 中创建一个按钮,我可以:指示数字 i,单击按钮以获取报价编号 i 的内容。
在我的 App.js 中,我有我的状态:
state = {
...
number: '',
offerToCheck: '',
};
我用我的按钮调用的功能是这样的
checkMessage() {
const offerToCheck = DemandeOffre.methods.getOfferNumber(this.state.number).call();
this.setState({ offerToCheck });
}
this.state.number 是我在 render() 中给他的数字:
<div>
<label>Check Offer</label>
<input
value={this.state.number}
onChange={event => this.setState({ number: event.target.value })}
/>
</div>
<button onClick={this.checkMessage}>Check</button>
<p> The offer you checked goes as follows : {this.state.offerToCheck}. </p>
当我尝试这样使用它时,我得到了"TypeError: this is undefined"
Reactconst offerToCheck = DemandeOffre.methods.getOfferNumber(this.state.number).call();
在线的错误。
我尝试了各种方法,例如使用绑定(this)。当我这样做时,单击按钮只会让我进入一个空白页面。
我对反应不是很熟悉,所以我不知道我是否已经彻底解释了我的问题。希望我能找到解决办法。
解决方案
为了this
不被未定义,您可以像这样定义函数:checkMessage = () => {...}
. 此外,对合约的调用会返回一个承诺,因此要从那里获取您必须使用的值,await
或者,您可以在此处.then()
阅读更多信息。您现在执行此操作的方式,当您使用它来设置组件的状态时,该变量将不会具有正确的值。offerToCheck
推荐阅读
- java - Quartz 调度程序产生“ResultSet is closed”异常
- python-3.x - 如何在 docker 文件中包含 Python 包?
- node.js - 如何实现在 fcm 上创建新文档时触发推送通知的功能?
- android - Android Q 上仅 DNS 的 VPN 服务
- python - 从数据框中提取具有列名的非零数据
- sql - 如果值已经存在则更新 vb 以访问数据库
- python - Tensorflow:sess.run([x]) 不起作用,但 sess.run([y]) 使用相同的 feed_dict
- android - 没有波纹时如何使用圆形蒙版添加自定义彩色圆圈波纹
- python - 熊猫分组忽略某些行值
- html - 如何使用 HTML 中的 IText5 确保段落与同一页面保持一致