当前位置: 首页 > article >正文

快速了解以太坊多种代币标准

前言

本文主要介绍以太坊ERC20、ERC721、RC1155三种代币标准相关介绍以及特点;

ERC20代币标准

概念:同质化代币标准(等值)

核心方法

  • name(): 代币名称
  • symbol(): 代币简写
  • decimals(): 代币可以分割到的小数位数
  • totalSupply(): 代币的总供应量
  • balanceOf(address _owner): 特定地址所有者的代币余额
  • transfer(address _to, uint256 _value): 从调用者的地址转移 指定量的代币到地址
  • transferFrom(address _from, address _to, uint256 _value): 允许支出者 从账号1转移一定量的代币到账号2
  • approve(address _spender, uint256 _value): 允许 支出者 从调用者的账户多次取回总共定量的代币
  • allowance(address _owner, address _spender): 返回支出者仍然被允许从所有者提取的代币数量

核心事件

  • Transfer(address indexed _from, address indexed _to, uint256 _value):在代币被转移时触发
  • Approval(address indexed _owner, address indexed _spender, uint256 _value):调用 approve 方法时触发

补充:OpenZeppelin库中的ERC20已经非常全面可以在此基础上扩展

ERC721代币标准

概念:非同质化代币(唯一性)

核心方法

  • balanceOf(address _owner):该地址拥有的代币数量
  • ownerOf(uint256 _tokenId):拥有此代币的地址
  • safeTransferFrom(address _from, address _to, uint256 _tokenId, bytes data):安全地将代币从一个地址转移到另一个地址
  • transferFrom(address _from, address _to, uint256 _tokenId):将代币从一个地址转移到另一个地址
  • approve(address _approved, uint256 _tokenId):授权某个地址管理特定的ERC721代币
  • getApproved(uint256 _tokenId):获取被授权管理特定代币的地址
  • setApprovalForAll(address _operator, bool _approved):将一个操作者地址设置为被批准或取消批准管理所有代币的权利
  • isApprovedForAll(address _owner, address _operator):查询一个操作者是否被批准管理某个所有者的所有代币
  • ERC721Metadata是 ERC721 标准的一个非常重要的扩展 :增加了名字(name)”、“符号(symbol)”和“元数据(tokenURI)”三个方法

核心事件

  • Transfer(address indexed _from, address indexed _to, uint256 indexed _tokenId):在代币被转移时触发
  • Approval(address indexed _owner, address indexed _approved, uint256 indexed _tokenId):在一个地址被授权管理另一个地址的特定代币时触发
  • ApprovalForAll(address indexed _owner, address indexed _operator, bool _approved):当一个操作者被授权或取消授权管理某个所有者的所有代币时触发

补充说明 :
一般情况下借助OpenZeppelin库中的ERC721,在开发nft合约时候需要配合ipfs去中心化服务用来存储元数据

ERC1155代币标准

概念:管理多种类型的代币(包含了同质化代币和非同质化)
主要函数

  • balanceOf(account, id):查询帐户对于特定代币 id 的余额
  • balanceOfBatch(accounts, ids):同时查询多个账户对于多个代币 id 的余额
  • safeTransferFrom(from, to, id, amount, data):安全地从一个账户向另一个账户转移特定 id 的代币
  • safeBatchTransferFrom(from, to, ids, amounts, data):批量转移多种代币从一个账号到另一个账号
  • setApprovalForAll(address _operator, bool _approved):将一个操作者地址设置为被批准或取消批准管理所有代币的权利
  • isApprovedForAll(address _owner, address _operator):查询一个操作者是否被批准管理某个所有者的所有代币

元数据扩展

  • uri(uint256 _id):一个代币的 ID 来获得一个 URI
    元数据结构:非同质代币的描述文件,存储在例如ipfs上;
  • name: 代币的名称
  • description: 代币的描述
  • image: 代表代币的图片链接
  • properties: 一个包含额外信息的对象,例如代币的稀有度、或代币具体的属性数值等
# json文件
{  
"name": "Magic Sword", // 代币的名称
"description": "A rare sword imbued with magical powers.", // 代币的描述
"image": "https://images.example/magicsword.png",  //代币的图片链接可以通过ipfs上传文件生成
"properties": {  
"damage": 35,  
"magic": 50  
}  //额外信息的对象
}

补充说明:开发一般使用OpenZeppelin库中的ERC1155的库来开发

代币标准特点

ERC20:

Ethereum 网络上最出名且应用最广的代币标准

ERC721特征
  1. 非同质化:每个代币都有独特的属性
  2. 所有权追踪:智能合约能准确记录每个代币的所有者
  3. 元数据可选性:合约可以包含一个可选的 URL,指向代币的元数据,如图片、文本等
ERC1155特点
  • 灵活性: 合约可以支持多种代币类型,包括但不限于可替代代币、不可替代代币等。
  • 节省交易成本: ERC1155 允许用户在单个交易中转移多种代币,大幅减少交易成本,并提高效率。

教程到此结束,更多相关,,https://t.me/+_QibemQqIIg1OTY1


http://www.kler.cn/a/594793.html

相关文章:

  • 前端进化:从焦虑到机遇的范式转型之路
  • navicat 创建Oracle连接报错:ora28040 没有匹配的验证协议
  • TCP/UDP传输过程
  • AI辅助的逆向分析
  • MutableList 和 ArrayList 区别
  • 画出ConcurrentHashMap 1.8的put流程图,记住CAS和synchronized的结合
  • 【Oracle资源损坏类故障】:详细了解坏块
  • 视觉Transformer架构的前沿优化技术与高效部署
  • 微服务》》Kubernetes (K8S) 集群配置网络》》Calico
  • Java 中 LinkedHashMap 的底层数据结构及相关分析
  • 甘特图dhtmlx-gantt 一行多任务
  • 【el-select 一键便捷全选】
  • 服务器托管如何抵御网络病毒?
  • AI小白的第七天:必要的数学知识(四)
  • Java面试核心知识点 深度拆解+高频易错
  • 设计模式之责任链模式:原理、实现与应用
  • 问题记录(一)——引入WebSocket依赖时的不兼容或冲突问题
  • 2025最新电脑IP地址修改方法:Win系统详细步骤
  • C++ - 从零实现Json-Rpc框架-1(JsonCpp Muduo 异步操作)
  • 四、小白学JAVA-石头剪刀布游戏