DDR:教程:如何在web应用程序中将ENS地址转换为ETH地址_DRE

在本教程中,我将向大家展示我能想到的最简单的例子,如何在web应用程序中将ENS地址转换为ETH地址。

知道如何做是很有价值的,因为大多数智能合约只接受ETH地址,而不接受ENS地址。

介绍

如何做到这一点的简单答案是,用户只需要从子图中查询数据。

有多种方法转换一个ENS地址:

1:使用ENS.js

我曾经使用这个库来转换ENS地址。但是,它不适用于位于layer2的应用程序,所以我不会展示如何以这种方式进行操作。

2:使用ENS提供的去中心化子图

金色热搜榜:QTUM居于榜首:根据金色财经排行榜数据显示,过去24小时内,QTUM搜索量高居榜首。具体前五名单如下:QTUM、HPT、SYS、IOST、HT。[2020/8/4]

这是最可靠的方法,因为它是去中心化的。然而,当我在ENSdiscord中询问时,他们说不要用这个。此外,每次用户在你的应用程序上查询这个子图时,你都要花钱——所以它不是免费的。我认为ENS计划告诉每个人使用这个子图,但我可能是错的,我不确定他们会等待什么。

3:使用ENS提供的中心化子图

这个子图是免费使用的,也是巴黎高等师范学院推荐人们使用的。这是我将教如何使用这里。

金色晨讯|1月28日隔夜重要动态一览:21:00-7:00关键词:Bitfinex、BCH、以色列证券管理局、欧科集团、乌克兰

1. Ditto音乐公司将推出提供快速区块链解决方案的应用程序Bluebox。

2. 针对Bitfinex及Tether的四项集体诉讼已被合并。

3. BCH矿工威胁将进行分叉,除非撤回12.5%的奖励基金提议。

4. 以色列证券管理局寻求反馈信息以查明阻碍该国区块链企业发展的潜在法规。

5. 欧科集团设立1000万元疫情防治专项基金。

6. 乌克兰将监督1200美元以上的加密货币交易。

7. 以色列计划为分布式账本技术支持(DLT)数字资产交易平台起草法规。

8. 杭州33复杂美慈善平台利用区块链登记疫情救援信息并捐助10万元物资。

9. BTC现报8940美元,近24小时上涨1.85%,市值约为1624亿美元。[2020/1/28]

项目设置

金色独家 中高会区块链产业联盟理事长朱涛:司法监管滞后是通病:美国证券交易委员会(SEC)将于北京时间6月14日凌晨两点在佐治亚州亚特兰大州立大学举行一次市民会议(Town Hall Meeting),就加密货币行业、网络安全等投资者关心的问题展开讨论。针对此次会议,金色财经邀请中高会区块链产业联盟理事长朱涛对本次会议作出解读,朱涛表示:司法监管滞后是通病。我前天参加中美的一个交流会,他们说美国除了联邦法律规定的电子白条合法外,政客们也没有研究出完善的新的法律。之所以有的地方有宣布,也是为了引领人们去做事。[2018/6/13]

首先,在本地克隆repo。然后,安装所有依赖项并运行本地服务器。如果要检查localhost,就应该在页面上看到一个输入。如果输入了一个有效的ENS地址,就将看到有效性和ETH地址正在浏览器控制台中登录,确认转换。

金色财经现场报道 曹寅:区块链概念并不是中本聪最先提出:在GBLS全球无眠区块链领袖峰会上,爱沙尼亚数字国际计划顾问曹寅表示:区块链最早是爱沙尼亚大学中提出的框架,并不是中本聪最先提出。[2018/6/6]

解释

既然你已经有了所有的代码,我将用本教程的剩余部分来解释它如何线性工作。

在主页上有一个输入(src/pages/index.tsx)。输入时,它设置inputAddress状态变量。

每当这个状态变量发生变化时,它都会被这里的useENSAddresshook检测到:

现在打开Reacthook的文件(src/components/useENSAddress.ts)。你可以看到它使用了里面的useEffect的hook。这个useEffect的依赖项列表中有一个inputAddress参数。这会导致useEffect主体在每次inputAddress改变时(通过用户输入)被调用。

useEffect(():any=>{...bodycodehere...},)

那么当调用useEffect的主体时会发生什么呢?几乎所有发生的都是run方法被调用。

run方法通过调用其他方法来设置ETH地址。让我们检查一下那个方法,因为它是调用堆栈中的下一个。

打开src/stores/ensStore.ts。里面是queryENSForETHAddress方法。

首先,它进行软检查,看看传入的值是否为ENS地址。

然后,它查询由HTTP_GRAPHQL_ENDPOINT定义的子图。为了获得我们想要的数据,我们需要创建一个graphql查询。这就是getQueryENSForETHAddress方法的作用。

现在转到那个方法。它正在查询子图以获取传入的ENS地址的数据。

如果你想知道我是怎么想通了如何创建此查询,那么你需要更多关于thegraph和graphql工作的知识。基本上,每个子图都有一个游乐场,我一直在摆弄它,直到我得到了所需的数据。

例如,在playground中,可以输入查询,然后按下播放键,以便查看返回的数据。

现在,如果返回到queryENSForETHAddress,你可以看到数据存储在result变量中:

return语句的基本意思是,ifvalidENSaddresspassedin,returntheETHaddress…otherwise,return0。你还会注意到返回的数据采用来自getQueryENSForETHAddress。

一旦它返回,它可以追溯到useEffect中useENSAddress.ts的文件和设置ethAddress状态变量。

然后,返回三个值:

return

第一个值表示传入的值是否有效。第二个值是从子图中检索到的ETH地址。第三个值表示这些值当前是否正在加载。

差不多就是这样了。完成这个过程后,我将这些值记录到主页上的控制台。

现在你已经知道如何将第一层和第二层的ENS地址转换为ETH地址。

Source:https://medium.com/coinmonks/how-to-convert-ens-address-to-eth-address-in-js-251c6209c208

来源:金色财经

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

区块博客

MATICAVAX:下行难以继续-配置要点分析_Huobi Polkadot

从去年下半年开始算起,到现在,绝大部分币种都翻了好几倍,还有很多都是几十倍几百倍。但是从我文章里面进来联系我的基本上保本都是不错的了,人们很难跟上币圈发展的红利,都当作了肥料,滋养了各种或优秀的.

[0:31ms0-4:83ms