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-11.18%
查看原文
此頁面可能包含第三方內容,僅供參考(非陳述或保證),不應被視為 Gate 認可其觀點表述,也不得被視為財務或專業建議。詳見聲明
  • 讚賞
  • 6
  • 分享
留言
0/400
社恐元宇宙vip
· 8小時前
超市买菜都比这简单吧
回復0
雏菊独角兽vip
· 8小時前
哎呀比超市花架子还神奇的协议小花花~
回復0
GateUser-a180694bvip
· 9小時前
期待这个dex能改变nft交易痛点
回復0
去中心化老干部vip
· 9小時前
开盘了啊哥们来整个
回復0
ThatsNotARugPullvip
· 9小時前
智能合约那块巨麻烦的
回復0
瀑布式抄底vip
· 9小時前
挂单买卖这种low爆了
回復0
交易,隨時隨地
qrCode
掃碼下載 Gate APP
社群列表
繁體中文
  • 简体中文
  • English
  • Tiếng Việt
  • 繁體中文
  • Español
  • Русский
  • Français (Afrique)
  • Português (Portugal)
  • Bahasa Indonesia
  • 日本語
  • بالعربية
  • Українська
  • Português (Brasil)