什么是事件Evnet?
就是以EVM日志基础设备提供一个接口,当被事件调用时,出发参数存储到日志中,其与合约地址关联,并记录到区块链中。关系就是:区块链是打包交易区块组成的链条,每一个交易会包含0到多个记录,日志代表智能合约所触发事件。
DAPP中,监听了事件,当事件发生时,会回调。当然要注意的就是,日志和事件在合约内是无法被访问,即使是创建日志的合约。
在Solidity代码中,使用event关键字来定义一个事件,如:
eventEventName(addressbidder,uintamount);
这个用法和定义函数式一样的,并且事件在合约中同样可以被继承。触发一个事件使用emit(说明,之前的版本里并不需要使用emit),如:
0x5a80巨鲸将3.8万枚AAVE转至CEX:6月26日消息,据Lookonchain监测,0x5a80开头巨鲸地址30分钟前通过多个地址将3.8万枚AAVE(约合246万美元)转至CEX。今日早些时候,0x5a80开头巨鲸地址在过去24小时内增持257,147枚AAVE(约合1720万美元),当前总计持有474,579枚AAVE(约合3180万美元)。[2023/6/26 22:00:33]
emitEventName(msg.sender,msg.value);
触发事件可以在任何函数中调用,如:
functiontestEvent()public{emitEventName(msg.sender,msg.value);}
以太坊网络当前已销毁333.94万枚ETH:金色财经报道,据Ultrasound数据显示,截止目前,以太坊网络总共销毁3339420.20枚ETH。其中,OpenSea销毁230050.65枚ETH,ETHtransfers销毁285575.61枚ETH,UniswapV2销毁179568.86枚。注:自以太坊伦敦升级引入EIP-1559后,以太坊网络会根据交易需求和区块大小动态调整每笔交易的BaseFee,而这部分的费用将直接燃烧销毁。[2023/5/28 9:46:49]
监听事件
通过上面的介绍,可能大家还是不清楚事件有什么作用,点击”UpdataInfo”按钮之后,虽然调用智能合约成功,但是当前的界面并没有得到更新。使用事件监听,就可以很好地解决这个问题,让看看如何实现。
比特币全网未确认交易数量为6698笔:金色财经报道,据BTC.com数据显示,目前比特币全网未确认交易数量为6698笔,全网算力为231.64 EH/s,24小时交易速率为2.58交易/s,目前全网难度为30.98 T,预测下次难度上调2.66%至31.80 T,距离调整还剩2天5小时。[2022/9/12 13:23:26]
修改合约,定义事件及触发事件
先回顾一下合约代码:
pragmasolidity^0.4.21;contractInfoContract{stringfName;uintage;functionsetInfo(string_fName,uint_age)public{fName=_fName;age=_age;}functiongetInfo()publicconstantreturns(string,uint){return(fName,age);}}
区块链数据分析工具Dune新增支持团队协作功能:7月7日消息,区块链数据分析工具Dune宣布在查询和仪表板中新增支持团队协作功能,还会在接下来的几个月内推出更多如私人内容等的功能。[2022/7/7 1:58:37]
首先,需要定义一个事件:
eventInstructor(stringname,uintage);
这个事件中,会接受两个参数:name和age,也就是需要跟踪的两个信息。
然后,需要在setInfo函数中,触发Instructor事件,如:
functionsetInfo(string_fName,uint_age)public{fName=_fName;age=_age;emitInstructor(_fName,_age);}
在web3与智能合约交互实战时,点UpdataInfo按钮之后,会调用setlnfo函数,触发Instructor事件。
使用Web3监听事件,刷新UI
现在需要使用Web3监听事件,刷新UI。先回顾下之前的使用Web3和智能合约交互的代码:
<script>if(typeofweb3!=='undefined'){web3=newWeb3(web3.currentProvider);}else
{web3=newWeb3(newWeb3.providers.HttpProvider("http://localhost:7545"));}web3.eth.defaultAccount=web3.eth.accounts;varinfoContract=web3.eth.contract(ABIINFO);varinfo=infoContract.at('CONTRACTADDRESS');info.getInfo(function(error,result){if(!error){$("Billions项目组button").click(function(){info.setInfo($("Billions项目组age").val());});</script>
现在可以不需要info.getInfo()来获取信息,而改用监听事件获取信息,先定义一个变量引用事件:
varinstructorEvent=info.Instructor();
然后使用.watch()方法来添加一个回调函数:
instructorEvent.watch(function(error,result){if(!error){$("#info").html(result.args.name+'('+result.args.age+'yearsold)');}else{console.log(error);}});
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。