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

Polkadot-API (PAPI) 简介与使用指南

在 Polkadot 生态系统中,去中心化应用(dApp)、网页和钱包的开发者通常使用 JavaScript 和 TypeScript 进行开发。与基于 Polkadot SDK 的区块链进行交互,传统上主要依赖于 Polkadot JS 库。然而,最近波卡生态中出现了一款备受关注的新工具——Polkadot-API (PAPI),它提供了更现代化、模块化的开发体验,并针对轻客户端进行了优化。本文将介绍 PAPI 的特点、环境搭建、基本用法以及其在实际开发中的优势。

PAPI 的特点

Polkadot-API(PAPI)是一个为去中心化应用程序(dApp)开发者提供的模块化、可组合的库,专门针对“轻客户端优先”方法设计。其目标是提供一套全面的工具,帮助开发者构建高效、完全去中心化的应用程序。PAPI 具备以下特点:

轻客户端优化:通过新版本的 JSON-RPC 规范支持完全去中心化的交互。
强大的 TypeScript 支持:通过链上元数据自动生成类型定义和文档,简化开发工作,并实现无缝访问链上存储、常量、交易、事件和运行时调用。
多链兼容性:允许开发者同时连接多个区块链,并提供多描述符支持和运行时更新兼容性检查。
性能优化:利用原生 BigInt 类型、动态导入和模块化子路径来避免捆绑不必要的资源,从而提高性能。
灵活的 API 选项:支持基于承诺和可观察的 API,方便与 Polkadot.js 集成,并可通过浏览器扩展或私钥提供签名选项。
这一切使得 PAPI 成为构建去中心化应用程序的理想工具,既提高开发效率,又优化了应用的性能和可扩展性。从实际使用来看,PAPI 最吸引人的特点之一是它能够基于链的 Metadata 轻松生成 TypeScript 类型定义,详细文档可参考 Polkadot 官方文档,或访问 PAPI 官方网站。

Polkadot 官方文档 :

https://docs.polkadot.com/develop/toolkit/api-libraries/papi/

PAPI 官方网站: https://papi.how/

环境搭建

安装依赖

首先我们需要按照它,通过 npm 或者 yarn。

npm i polkadot-api

获取链的 Metadata
像波卡的 relay chain,在脚本中已经有了默认的支持,可以直接使用名字来获取,当你运行帮助,可以得到列表, polkadot,kusama 以及它们的系统平行链都有。

npx papi add -h
在添加的时候可以给一个名字

npx papi add dot -n polkadot
也可以添加一个不在列表里面的链,使用 -w 选项。我们启动本地服务器一条链,使用默认端口,并添加。

npx papi add asset -w ws://10.0.0.11:9944
在成功的添加后,项目目录下会出现一个隐藏目录,名字是.papi ,里面会根据获取的 Metadata 生成类型文件。

它的原理是在 packagejson 里面增加一个依赖,包含 descriptor。

“dependencies”: {

编程体验
为了查看后台日志方便调试,代码都是和本地的节点进行交互。从官方文档来看,client 是支持不同的模式的,比如 Smoldot,这里只演示基本的 web 方式。

获取 Client API
首先通过 ws provider 指定链的 RPC 节点地址和端口,然后初始化一个 client。所以的类型是通过 getTypedApi 方法来获取的,这种获取的方式十分便捷,对于习惯强类型编程的开发者非常友好。

类型的定义就是上一个步骤使用命令生成的。

import { asset } from ‘@polkadot-api/descriptors’;
得到常量和变量
然后通过 api 可以简单和链交互,这里获取 balances 里面的一个常量和变量。代码分别打印出帐号的最小余额和帐号 Alice 的可用余额。

import { asset } from ‘@polkadot-api/descriptors’;
‍发送交易
这里完成一个最简单的从 Alice 到 Bob 的转账操作。得到 api 后,我们分别导入 Alice 和 Bob 二个帐号,并初始化 Alice 的 signer,把 Bob 的 public key 转换成 MultiAddress 的格式。最后签名并发送这个交易。

import { MultiAddress } from “@polkadot-api/descriptors”
当交易成功完成后,结果的格式如下

{
监听事件
在 Dapp 的开发中,对事件的处理也是必不可少的,下面的代码演示链如何获取。

import { asset } from ‘@polkadot-api/descriptors’;
获取的事件格式如下。对于监听还可以应用一些 Filter,可以通过发送者,接收者地址过滤等等,这些可以自己去尝试。

{

总结
PAPI 相较于传统的 Polkadot JS 库,提供了更现代化的开发体验,特别是对 TypeScript 类型定义 的自动生成,使得开发者能够更清晰地理解链上数据结构,极大地提高了开发效率。其模块化设计、轻客户端优先的策略以及多链兼容性,使其成为 Polkadot 生态中值得关注的新工具。当然,由于 PAPI 仍在持续优化中,开发者在使用过程中可能会遇到一些 bug,欢迎大家积极反馈并贡献 PR。希望 PAPI 能进一步推动波卡生态发展,为开发者提供更便捷的区块链交互方式!

「区块链技术开发入门 17 期」
正式开启报名
由 OneBlock+ 和 Polkadot 联合推出的「区块链技术开发入门 17 期 | Polkadot 上的 Solidity 开发」 即将启程!本期课程将于 2025 年 3 月 7 日 正式开课,历时 6 周,包含 6 个录播课时、6 个 Task 任务 及 多个 Workshop。通过系统化学习与实践,助你深入探索区块链技术,开启加密未来的新篇章!✨ 本期课程完全免费开放,采用申请入学制,名额有限!立即点击下方链接填写申请表,审核通过后我们将主动联系你,锁定学习席位! 立即申请入学:https://wj.qq.com/s2/17653871/18t2/

免责声明:由 PaperMoon 提供并包含在本文中的材料仅用于学习目的,它们不构成财务或投资建议,也不应被解读为任何商业决策的指导。我们建议读者在做出任何投资或商业相关的决定之前,进行独立研究并咨询专业人士。PaperMoon 对根据本文内容采取的任何行动不承担任何责任。

相关文章:

Polkadot-API (PAPI) 简介与使用指南

在 Polkadot 生态系统中,去中心化应用(dApp)、网页和钱包的开发者通常使用 JavaScript 和 TypeScript 进行开发。与基于 Polkadot SDK 的区块链进行交互,传统上主要依赖于 Polkadot JS 库。然而,最近波卡生态中出现了一…...

LabVIEW用户界面设计原则

在LabVIEW开发中,用户界面(UI)设计不仅仅是为了美观,它直接关系到用户的操作效率和体验。一个直观、简洁、易于使用的界面能够大大提升软件的可用性,尤其是在复杂的实验或工业应用中。设计良好的UI能够减少操作错误&am…...

Java中的synchronized:使用与锁升级机制

在Java并发编程中,synchronized关键字是实现线程同步的重要工具。它能够确保多个线程在访问共享资源时的线程安全性。随着Java版本的更新,synchronized的底层实现也在不断优化,尤其是引入了锁升级机制,显著提高了性能。本文将详细…...

简述MySQL主从复制原理及其工作过程,配置一主两从并验证

MySQL主从复制原理:MySQL主从复制是一种常用的数据同步技术,它通过将一个MySQL数据库服务器(主服务器)的数据实时复制到一个或多个从服务器,从而实现数据的备份、读写分离以及高可用性等目标. 基于binlog的主从同步 #主服务器配…...

MySQL8.0 innodb Cluster 高可用集群部署(MySQL、MySQL Shell、MySQL Router安装)

简介 MySQL InnoDB集群(Cluster)提供了一个集成的,本地的,HA解决方案。Mysq Innodb Cluster是利用组复制的 pxos 协议,保障数据一致性,组复制支持单主模式和多主模式。 InnoDB Cluster组件: …...

【时时三省】(C语言基础)简单的算法举例

山不在高,有仙则名。水不在深,有龙则灵。 ----CSDN 时时三省 判定2000—2500年中的每一年是否为闰年,并将结果输出。 本先分析闰年的条件: (1)能被4整除,但不能被100整除的年份都是闰年&…...

走进 Tcl 语言:历史、特性与应用

亲爱的小伙伴们😘,在求知的漫漫旅途中,若你对深度学习的奥秘、Java 与 Python 的奇妙世界,亦或是读研论文的撰写攻略有所探寻🧐,那不妨给我一个小小的关注吧🥰。我会精心筹备,在未来…...

Day42(补)【AI思考】-编译过程中语法分析及递归子程序分析法的系统性解析

文章目录 编译过程中语法分析及递归子程序分析法的系统性解析**一、总览:编译流程中的语法分析****1. 编译过程核心步骤** **二、语法分析的核心任务****1. 核心目标****2. 现实类比** **三、递归子程序分析法的本质****1. 方法分类****2. 递归子程序分析法的运作原…...

Effective Objective-C 2.0 读书笔记——内存管理(上)

Effective Objective-C 2.0 读书笔记——内存管理(上) 文章目录 Effective Objective-C 2.0 读书笔记——内存管理(上)引用计数属性存取方法中的内存管理autorelease保留环 ARCARC必须遵循的方法命名原则ARC 的自动优化&#xff1…...

软件测试覆盖率详解

🍅 点击文末小卡片 ,免费获取软件测试全套资料,资料在手,涨薪更快 一、覆盖率概念 覆盖率是用来度量测试完整性的一个手段,是测试技术有效性的一个度量。分为:白盒覆盖、灰盒覆盖和黑盒覆盖;测…...

控制玉米株高基因 PHR1 的基因克隆

https://zwxb.chinacrops.org/CN/10.3724/SP.J.1006.2024.33011...

windows10本地的JMeter+Influxdb+Grafana压测性能测试,【亲测,避坑】

一、环境,以下软件需要解压、安装到电脑上。 windows10 apache-jmeter-5.6.3 jdk-17.0.13 influxdb2-2.7.11 grafana-enterprise-11.5.1二、配置Influxdb,安装完默认连接http://localhost:8086/。打开连接,配置如下。 开启Influxdb&#xf…...

那些数据库函数那些事儿

stdio 1.基本概念 文件: 一组相关数据的集合 文件名: 01.sh //文件名 2.linux下的文件类型 b block 块设备文件 eg: 硬盘 c character 字符设备文件 eg: 鼠标,键盘 d directory 目录文件 eg: 文件夹 - regular 常…...

Excel中不用复杂公式根据指定X列的数值N复制整行数据N行简单方法

Excel中不用复杂公式根据指定X列的数值N复制整行数据N行简单方法 1、在“数据表”sheet1中对指定X列(假设X列的数字从X2开始到Xn结束)求和,和为Y。 2、在“数据表”sheet1数据列之外新建一列Z,Z1输入表头“匹配数据列”&#xff…...

如何在 Java 后端接口中提取请求头中的 Cookie 和 Token

个人名片 🎓作者简介:java领域优质创作者 🌐个人主页:码农阿豪 📞工作室:新空间代码工作室(提供各种软件服务) 💌个人邮箱:[2435024119qq.com] 📱个人微信&a…...

【Python网络爬虫】爬取网站图片实战

【Python网络爬虫】爬取网站图片实战 Scrapying Images on Website in Action By Jackson@ML *声明:本文简要介绍如何利用Python爬取网站数据图片,仅供学习交流。如涉及敏感图片或者违禁事项,请注意规避;笔者不承担相关责任。 1. 创建Python项目 1) 获取和安装最新版…...

SAP ABAP VA05增强

SE18 输入增强的BADI名称:BADI_SDOC_WRAPPER 进入后,点击Interface。 进入后,点击显示对象清单。 双击增强类,下面有之前做好的增强类,没有的可以自己创建一个。 IF_BADI_SDOC_WRAPPER~ADAPT_RESULT_COMP 代码 METHOD if_badi_sdoc_wrapper~adapt_result_comp."…...

八大排序——简单选择排序

目录 1.1基本操作: 1.2动态图: 1.3代码: 代码解释 1. main 方法 2. selectSort 方法 示例运行过程 初始数组 每轮排序后的数组 最终排序结果 代码总结 1.1基本操作: 选择排序(select sorting)也…...

【清晰教程】本地部署DeepSeek-r1模型

【清晰教程】通过Docker为本地DeepSeek-r1部署WebUI界面-CSDN博客 目录 Ollama 安装Ollama DeepSeek-r1模型 安装DeepSeek-r1模型 Ollama Ollama 是一个开源工具,专注于简化大型语言模型(LLMs)的本地部署和管理。它允许用户在本地计算机…...

教程 | Proxmox VE(PVE)安装全流程指南(末尾附镜像及快速配置脚本)

Proxmox VE 是一款基于 Debian 的开源虚拟化平台,支持 KVM 虚拟机和 LXC 容器,广泛用于企业级虚拟化部署。 一、安装前准备 1. 硬件要求 CPU:64位处理器(Intel VT/AMD-V 虚拟化支持)内存:至少 4GB&#x…...

【matlab优化算法-17期】基于DBO算法的微电网多目标优化调度

基于蜣螂DBO算法的微电网多目标优化调度 一、前言 微电网作为智能电网的重要组成部分,其优化调度对于降低能耗、减少环境污染具有重要意义。本文介绍了一个基于Dung Beetle Optimizer(DBO)算法的微电网多目标优化调度项目,旨在通…...

如何使用qt开发一个xml发票浏览器,实现按发票样式显示

使用Qt开发一个按发票样式显示的XML发票浏览器,如下图所示样式: 一、需求: 1、按税务发票样式显示。 2、拖入即可显示。 3、正确解析xml文件。 二、实现 可以按照以下步骤进行: 1. 创建Qt项目 打开Qt Creator,创…...

八股文-2025-02-12

BFC BFC属于普通流。BFC全称是Block Formatting Context,意思就是块级格式化上下文。你可以把BFC看做元素的一个属性,当元素拥有BFC属性,这个元素就可以看作是隔离了的独立容器,容器里边的元素不会影响到容器外部的元素.https://b…...

解析 JavaScript 面试题:`index | 0` 确保数组索引为整数

文章目录 一、JavaScript 中的数字类型二、按位或运算符 | 的作用(一)对于整数(二)对于小数(三)对于非数字值 三、用于数组索引的意义 在 JavaScript 面试中,常常会涉及到一些看似简单却蕴含着深…...

苹果手机快捷指令----敲击背面实现自动插入日期

前一段时间因为写文章,每一次总是在手机上面敲击日期觉得非常麻烦,于是自己鼓捣如何自动插入的办法。下面分享在网络上面查阅到的资料,由于实操的原因,遇到了很多困难。现在补充上去。先演示一遍效果。 https://www.bilibili.com…...

Base64 PDF解析器

<!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><title>Base64 PDF解析器</title><style>body {font-family: Arial, sans-serif;max-width: 800px;margin: 20px auto;padding: 20px;}.contain…...

SQL-leetcode—1393. 股票的资本损益

1393. 股票的资本损益 Stocks 表&#xff1a; ---------------------- | Column Name | Type | ---------------------- | stock_name | varchar | | operation | enum | | operation_day | int | | price | int | ---------------------- (stock_name, operation_day) 是这张…...

Java NIO基础与实战:如何提升IO操作性能

Java NIO 概述 Java NIO&#xff08;新 I/O&#xff09;是 Java 提供的一个更为高效的 I/O 处理框架。Java NIO&#xff08;New I/O&#xff09;是对传统 I/O&#xff08;java.io&#xff09;模型的改进&#xff0c;它引入了非阻塞 I/O 操作和面向缓冲区的数据读写方式&#x…...

46 map与set

目录 一、序列式容器和关联式容器 二、set系列的使用 &#xff08;一&#xff09;set和mutilset参考文档链接 &#xff08;二&#xff09;set类模板介绍 1、set类声明 2、set的构造和迭代器 3、set的增删查 &#xff08;三&#xff09;multiset类模板 1、multiset和se…...

GPT 系列模型发展史:从 GPT 到 ChatGPT 的演进与技术细节

从 GPT 到 ChatGPT&#xff0c;OpenAI 用短短几年时间&#xff0c;彻底改变了自然语言处理&#xff08;NLP&#xff09;的格局。让我们一起回顾这段激动人心的技术演进史&#xff01;&#x1f680; &#x1f539; GPT&#xff08;2018&#xff09;&#xff1a; 划时代的起点&a…...