NFT去中心化交易所开发实战:从智能合约到前端实现

robot
摘要生成中

从零打造NFT去中心化交易所

对于ERC-721协议的NFT来说,如何实现去中心化交易呢?目前主流的NFT交易所多采用挂单方式进行交易,类似于将商品陈列在超市货架上,买家觉得价格合适就可以购买。本文将通过编写智能合约和简单的前端页面,实现一个基础的NFT去中心化交易功能。

NFT简介

NFT(Non-Fungible Token)即非同质化代币,每个Token都是独一无二的,遵循ERC-721协议。通常每个NFT在钱包中会显示不同的图片,并有唯一ID进行区分。由于NFT的特性,无法像ERC-20代币那样通过价格曲线设定价格,因此常见的交易方式是订单簿形式。

Web3新手系列:从零实现一个NFT DEX

订单簿交易模式

订单簿模式主要分为两种:

  1. 定价单:卖家设定出售价格,买家觉得合适即可购买。
  2. 求购单:买家发出求购订单,卖家觉得价格合适即可出售。

一般来说,求购单价格会低于定价单。本文主要介绍定价单模式。

Web3新手系列:从零实现一个NFT DEX

NFT交易所基本功能

一个基础的NFT交易所应包含以下功能:

  1. 上架商品:将NFT按设定价格上架
  2. 购买商品:按NFT定价进行购买
  3. 收取手续费:按成交价格比例收取

上架商品流程

  1. 前端:用户选择NFT并设定价格,点击上架
  2. 合约:用户授权合约操作NFT

购买商品流程

  1. 前端:用户选择NFT,点击购买
  2. 合约:将买家资金转给卖家,NFT转给买家

Web3新手系列:从零实现一个NFT DEX

实现NFT交易所

1. 创建测试用NFT

可以使用Remix快速部署一个ERC-721协议的NFT合约用于测试。

Web3新手系列:从零实现一个NFT DEX

2. 编写智能合约

合约主要包含以下方法:

2.1 卖家上架NFT

流程:

  1. 用户选择NFT
  2. 设置价格
  3. 授权NFT给合约
  4. 调用上架方法

上架方法执行:

  1. 校验NFT所有权
  2. 添加上架记录
  3. 触发上架事件

Web3新手系列:从零实现一个NFT DEX

2.2 买家购买NFT

合约执行:

  1. 读取NFT数据
  2. 计算并扣除手续费
  3. 转移NFT给买家
  4. 触发购买事件

Web3新手系列:从零实现一个NFT DEX

2.3 取消上架

将上架记录的isActive字段设为false

Web3新手系列:从零实现一个NFT DEX

2.4 提取手续费

将合约中累积的手续费提取出来

Web3新手系列:从零实现一个NFT DEX

3. 开发前端界面

使用的主要工具:

  • Ant Design Web3:连接钱包和展示NFT
  • Wagmi:与钱包交互
  • Next.js + Vercel:部署项目

前端包含3个页面:

  • Mint:创建测试NFT
  • Buy:NFT交易商城
  • Portfolio:管理用户NFT

Web3新手系列:从零实现一个NFT DEX

3.1 连接钱包

使用Ant Design Web3的连接组件实现。

Web3新手系列:从零实现一个NFT DEX

3.2 Mint页面

使用wagmi的useWriteContract方法调用NFT合约的mint方法。

Web3新手系列:从零实现一个NFT DEX

3.3 Portfolio页面

展示用户拥有的NFT,支持上架和下架操作。

Web3新手系列:从零实现一个NFT DEX

3.4 Buy页面

展示已上架的NFT,支持购买操作。

Web3新手系列:从零实现一个NFT DEX

通过以上步骤,一个基础的NFT去中心化交易所就实现了。可以将前端部署到Vercel进行访问使用。

MINT-12.81%
此页面可能包含第三方内容,仅供参考(非陈述/保证),不应被视为 Gate 认可其观点表述,也不得被视为财务或专业建议。详见声明
  • 赞赏
  • 6
  • 分享
评论
0/400
社恐元宇宙vip
· 3小时前
超市买菜都比这简单吧
回复0
雏菊独角兽vip
· 3小时前
哎呀比超市花架子还神奇的协议小花花~
回复0
GateUser-a180694bvip
· 3小时前
期待这个dex能改变nft交易痛点
回复0
去中心化老干部vip
· 3小时前
开盘了啊哥们来整个
回复0
ThatsNotARugPullvip
· 3小时前
智能合约那块巨麻烦的
回复0
瀑布式抄底vip
· 3小时前
挂单买卖这种low爆了
回复0
交易,随时随地
qrCode
扫码下载 Gate APP
社群列表
简体中文
  • 简体中文
  • English
  • Tiếng Việt
  • 繁體中文
  • Español
  • Русский
  • Français (Afrique)
  • Português (Portugal)
  • Bahasa Indonesia
  • 日本語
  • بالعربية
  • Українська
  • Português (Brasil)