NFT:NFT 教程 - 如何展示 Flow 和 IPFS 上的 NFT 收藏品_FLOKIPUP币

译文出自:登链翻译计划

译者:翻译小组

校对:Tiny熊

本文是NFT教程的的第二部分,本教程主要介绍Flow区块链、NFT和IPFS。请先阅读第一部分NFT教程-用Flow和IPFS创建NFT。

在本文中,我们将构建一个简单的React应用程序,该应用程序与Flow智能合约交互,以验证和获取用户拥有的NFT。然后,我们将解析NFT的元数据,以获得NFT的底层标的资产的IPFS位置。提醒一下我们正在打造的NFT,就像NBATopShot一样,只不过是不同的视频内容。

项目设置

本教程中,你需要运行Flow模拟器。如果你不记得如何启动,可以看看之前的文章或者查看FlowCLI文档。需要注意的是,Flow模拟器是Flow区块链在内存的模拟。所以,如果关闭了模拟器,你需要继续做以下工作:

启动Flow模拟器

部署项目

去中心化稳定币项目Ethena完成600万美元融资:7月17日消息,去中心化稳定币项目Ethena完成600万美元融资,Dragonfly领投。该项目将发行稳定币USDe,并通过将用户的部分抵押品转换为以太坊并质押,再通过永续合约做空相同数量的以太坊来保证稳定币抵押品价值的稳定。[2023/7/18 11:00:30]

铸造你的NFT

在本教程第一部分NFT教程-用Flow和IPFS创建NFT详细介绍了其中的每一个步骤。

此外,还需要在你的机器上安装NodeJS。你可以在这里安装。

和之前一样,你需要一个文本编辑器。

初始化React和安装依赖

在第一部分教程中创建的pinata-party项目目录下创建React应用。

要创建我们的应用程序,运行以下命令:

npxcreate-react-apppinata-party-frontend

BM:透明性和分叉能力是去中心化的关键考验:BM发推表示,很高兴看到DPOS证明了这样一个概念,攻击DPOS链的成本就是你的代币。这听起来似乎有点主观,但最终社区以去中心化的方式达成了共识。这就像POW依赖链下治理来解决sigwit和eth classic一样。归根结底,透明性和分叉能力是去中心化的关键考验。[2020/3/21]

当一切安装完成后,你会有一个新的目录,叫做pinata-party-frontend,切换到该目录,安装依赖。

首先,参考Flow文档,需要安装FlowJSSDK。前端的设置我们只需要按照Flow的文档进行即可:

npmi;exportdefaultTokenData;//rawTokenData

button{padding:10;height:30px;min-width:100px;cursor:pointer;}

现在,只要将新组件添加到App

声音 | 何一:去中心化交易平台相比合约交易而言对于行业更有重大意义:币安联合创始人何一在近日接受采访时称,大部分金融衍生品的交易用户需要更强的风险承压能力。而目前来看,币市风险本身波动就比较大,那合约交易类的风险就更大了,不适用于大多数人,适用于高风险偏好型的交易用户。去中心化交易平台可能没有合约交易赚钱快、手续费高、交易量大,但是对于整个行业有重大意义。[2019/2/28]

exportdefaultApp;

运行应用程序并尝试获取代币数据,它应该是这样:

这真是太酷了!我们正在查找指定的账户所拥有的NFT,然后从该代币中获取元数据。并显示该元数据,我们知道该元数据中的一个值解析为一个视频文件。让我们把它显示出来。

从IPFS获取媒体文件

你已经注册了一个Pinata账户,并通过Pinata上传界面将你的视频文件添加到IPFS。这意味着你已经可以从IPFS中获取内容了。在PinExplorer中,当你点击一个哈希值时,你会被带到PinataIPFS网关,在那里你的IPFS内容被解析并显示。为了教程更通用,我们还是从ProtocolLabs网关中获取它。

Podcast Panther以120 ETH价格成交,创VeeFriends NFT系列历史第二高交易记录:金色财经报道,据最新数据显示,Podcast Panther以120 ETH价格成交,约合 328,648.64 美元,创下VeeFriends NFT系列历史第二高交易记录;该系列交易额排名第一的 NFT 是“Empathy Elephant”,价格为 130 WETH,约合 491,683.60 美元。VeeFriends 由 Uber、Facebook、Twitter 及 Tumblr 等知名科技公司投资人Gary Vaynerchuk 创建,总计发行 10255 枚 NFT。为满足创业和商业社区需要,Gary Vaynerchuk 会每年举办“VeeCon”大会, VeeFriends NFT 持有者可以在购买后三年内获得“VeeCon”活动独家访问权,同时部分 NFT 销售资金也将会捐赠给慈善机构。[2022/3/4 13:37:23]

回到TokenData

《时代周刊》将拍卖3张NFT封面:金色财经报道,美国《时代周刊》将通过拍卖三个NFT来参与区块链数字艺术运动,灵感来自该杂志几十年来最具标志性的封面,主题是“Is ___ Dead?”。这三个NFT将在3月24日之前在加密艺术平台SuperRare上单独或作为系列出售。[2021/3/23 19:08:34]

p>);};exportdefaultTokenData;//rawTokenData.js

我们已经添加了一个video标签,它指向IPFS上的文件。你会注意到,这里拆分了uri值,以获得IPFS哈希值,这样就可以从IPFS网关获取对应内容。先介绍下那个URI。

我们用NFT创建的uri看起来像ipfs://Qm...。我们之所以这样创建,是因为IPFS桌面客户端默认允许你点击并打开这样的链接。另外,Brave浏览器也支持粘贴这样的链接。并且我们认为这种链接形式会随着IPFS的发展得到越来越多的支持。

然而,在这里下,我们需要在利用哈希来从IPFS公共网关获取内容,并在页面上显示。因此链接会是这样:

https://ipfs.io/ipfs/QmRZdc3mAMXpv6Akz9Ekp1y4vDSjazTx2dCQRkxVy1yUj6

现在,如果你访问我们的应用程序中获取代币数据,会看到如下界面:

这是一个真正的活的数字资产!你的视频可能会有所不同,但希望你在应用中感受到相同的体验。

最后

这是一个非常简单的应用,你可以做很多事情让它变得更漂亮,让它的交互性更强,甚至可以为它添加更多的Flow元素。FlowJSSDK的功能很强大,所以我推荐大家阅读一下文档。

在第二部分成功地使用Flow为应用添加了身份验证,创建了一个接口来获取NFT的信息,创建了一种方法来显示了原始元数据以及对应的底层标的资产。这一切都由Flow区块链和IPFS来保障。我们知道NFT是由谁拥有,也知道显示的内容是有效性,因为哈希值被编码到NFT中。

在本教程的最后一篇,我们将专注于创建一个迷你交易市场,让我们转移NFT。

本翻译由CellNetwork赞助支持。

来源:https://medium.com/pinata/how-to-display-your-nft-collection-like-nba-top-shot-with-flow-and-ipfs-6ba75048bf8a

参考资料

登链翻译计划:https://github.com/lbc-team/Pioneer

翻译小组:https://learnblockchain.cn/people/412

Tiny熊:https://learnblockchain.cn/people/15

NFT教程-用Flow和IPFS创建NFT:https://learnblockchain.cn/article/2271

NFT教程-用Flow和IPFS创建NFT:https://learnblockchain.cn/article/2271

这里安装:https://nodejs.org/en/

Flow文档:https://docs.onflow.org/flow-js-sdk/flow-app-quickstart

第一篇文章:https://learnblockchain.cn/article/2271

Pinata:https://pinata.cloud/

PinExplorer:https://pinata.cloud/pinexplorer

CellNetwork:https://www.cellnetwork.io/?utm_souce=learnblockchain

免责声明:作为区块链信息平台,本站所发布文章仅代表作者个人观点,与链闻ChainNews立场无关。文章内的信息、意见等均仅供参考,并非作为或被视为实际投资建议。

本文来源于非小号媒体平台:

登链社区

现已在非小号资讯平台发布105篇作品,

非小号开放平台欢迎币圈作者入驻

入驻指南:

/apply_guide/

本文网址:

/news/9781311.html

免责声明:

1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险

2.本文版权归属原作所有,仅代表作者本人观点,不代表非小号的观点或立场

上一篇:

盘点零知识证明代表性项目:如何影响和塑造区块链生态系统?

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

区块博客

[0:0ms0-3:720ms