跳至主要内容
本页面使用机器翻译自英语,可能包含错误或不清楚的语言。如需最准确的信息,请参阅英文原文。由于更新频繁,部分内容可能与英文原文有出入。请加入我们在 Crowdin 上的努力,帮助我们改进本页面的翻译。 (Crowdin translation page, Contributing guide)

Kaia 钱包 DApp 集成

目录

  1. 用户界面库
  2. 实用图书馆
  3. 提供商

导言

Kaia 钱包 是一个非托管钱包,类似于Metamask,额外支持 Kaia 特有的交易账户。 本文将指导您将 Kaia Wallet与去中心化应用程序(dApp)集成,从高层(抽象)到低层(细粒度)实现。

在本指南中,我们将把 Kaia 钱包 dApp 整合分为三大类:

  • 用户界面图书馆
  • 实用图书馆
  • 提供商
备注

上述库在引擎盖下使用 "提供者"。

1. 用户界面图书馆

许多 dApp 利用前端框架进行状态管理和提供反应式服务。 将 Kaia 钱包与此类应用程序集成的推荐方法是使用基于相同框架构建的用户界面库。

用户界面库为用户交互提供组件,如 "ConnectWallet "组件。 它们还能为您省去管理多账户和多网络等低级状态的麻烦。 您可以查看底层的 Utility Library或 [Provider] (#3-providers),了解复杂或低级的交互。

虽然大多数用户界面库都内置了对 Metamask 的支持,但由于 Kaia Wallet 的API是基于Metamask's构建的,因此集成起来也很容易。 即使一个库没有原生支持 Kaia 钱包,扩展它以集成 Kaia 钱包也很简单。 例如,这是 ReactNext.js 的 2 个流行库:

1.1. Appkit 示例

Appkit Hero Banner

通过 ReownAppkit 提供以下功能:

考虑因素:

备注

示例代码:kaikas-web3modal

1.2. Web3-Onboard 示例

Web3-Onboard Graphic

BlocknativeWeb3-Onboard提供以下功能:

  • 可配置的机载文本
  • 连接钱包、交换账户和交换网络的模式
  • 通知组件
  • (可选)注册 API 密钥以获取和呈现实时数据

考虑因素:

  • 您必须编写您的按钮
备注

2. 实用图书馆

kaia-sdk](#21-kaia-sdk) 和 ethers.js 等库的抽象程度足以简化区块链交互,同时还能直接调用 Provider API。

使用实用程序库连接账户或发送本地令牌(如 KAIA/ETH),在语法和代码行数*方面与直接调用提供商没有区别。 图书馆主要在以下方面有所改进:

  • 智能合约互动
    • 这些涉及 ABI、编码输入和解码输出。 如果没有库,这些代码可能会冗长且容易出错。
  • 错误处理
    • 字符串错误代码/信息被映射到具有自定义属性和方法的错误类。
  • 文件和类型安全

2.1. kaia-sdk

kaia-sdk是其他实用程序库(如 ethers.jsweb3.js)的插入式扩展集。 它允许您使用自己喜欢的库,同时为Kaia 特定方法提供第一方支持:

  • 交易、账户和账户密钥类型
  • 收费代表团
备注

示例代码:kaikas-web3klaytn

2.2. ethers.js 示例

etherthers.js最受欢迎的 JavaScript 工具库,用于与区块链进行交互。 它的目标是

  • 广泛:支持多种钱包格式、语言和功能
  • 稳健:全面的测试、文档和键入
备注

示例代码:kaikas-ethersjs

3. 提供商

最底层是提供程序 window.klaytn(Kaia 钱包本身)。 您可能更喜欢实用库,但了解提供程序接口有助于调试和理解依赖库如何工作。 要使用 Kaia 特有的方法,如 kaia_getAccountkaia_sendTransactionAsFeePayer 等,必须参考 [Kaia 的 JSON-RPC API][Kaia-API]。

让这个页面变得更好