Solana Web3.js 2.x版本发布:函数式编程重塑开发体验

robot
摘要生成中

Solana Web3.js 2.x:函数式编程的新时代

Solana Web3.js 在2023年11月发布了2.x版本,相较于1.x版本,新版本带来了显著的变化。本文将概括其主要改进。

虽然2.x版本刚刚发布,使用率尚不高,许多流行库也未迁移,但了解这些变化有助于未来的升级准备。

Web3 新手系列:现在升级 @solana/web3.js 2.x 开启函数式编程

版本对比

1.x版本使用起来相对简单,仅包含@solana/web3.js一个包,基于类的设计封装了大量常用操作。例如,Connection类提供了数十种方法,几乎涵盖了开发者所需的所有功能。

然而,这种设计也带来了一些问题。尽管开发者实际使用的功能可能很少,但整个代码库都会被下载到用户设备上,导致加载时间延长。

2.x版本采取了不同的方法。官方团队将原有代码库拆分为多个小模块,如@solana/accounts、@solana/codecs、@solana/rpc等。新版本放弃了基于类的实现,更多地采用单个函数,这有利于JavaScript代码构建时的优化。未使用的代码将被删除,不会下载到用户设备上。根据官方数据,使用新版本的DApp通常能实现30%的尺寸优化,对于使用功能较少的应用,优化比例可能更高。

这种变化对Solana团队的文档质量提出了更高要求。如何让开发者快速找到所需功能成为一个关键问题。目前,包名的语义性较好,从名称上就能大致了解其用途,这在一定程度上降低了开发者的迁移难度。

然而,由于刚发布不久,许多项目尚未迁移。一些示例和文档描述也不够完善,可能会给开发者带来一些困惑。

2.x版本的另一个重要特点是零依赖。这对于提高安全性至关重要,尤其是在2023年12月初@solana/web3.js 1.95.5和1.95.6版本遭遇供应链攻击后。新版本更多地使用本机功能,取消了外部依赖和Polyfills的引入,从而降低了安全风险。

主要变更

连接方式

2.x版本采用了更加函数式的方法来处理连接。不再使用Connection类,而是通过配置RPC请求地址来创建请求发送器。例如,发送交易时会自动发起HTTPS请求并建立WSS连接,订阅交易状态,在交易确认后返回交易哈希。

密钥对管理

公钥和私钥相关的操作也发生了重大变化。1.x版本常用的Keypair和PublicKey类不再存在,取而代之的是一系列函数。例如,现在使用await generateKeyPair()来生成密钥对,而不是之前的Keypair.generate()。

新的实现利用了JavaScript的Web Crypto API,使用了原生的Ed25519实现。这导致一些操作变成了异步的,但对于熟悉Promise的现代JavaScript开发者来说,这并不是一个大问题。

交易处理

2.x版本中,不再有Transaction和VersionedTransaction类。System Program相关的方法也需要从其他地方引入。例如,转账指令现在需要调用@solana-program/system中的getTransferSolInstruction函数。

新版本提供了函数式编程中常用的pipe形式。交易不再通过Connection发起,而是通过定义的RPC Provider生成特定函数来发起交易。这种方式虽然代码量略有增加,但提供了更强的可定制性。

React支持

值得注意的是,@solana/web3.js项目中还包含了一个名为@solana/react的库,提供了一些React Hook,内置了诸如signIn等功能。

结语

@solana/web3.js 2.x版本的发布展现了Solana团队持续改进的决心。新版本为开发者提供了一个高效、灵活、可定制的Solana网络交互方式,有望推动平台的进一步发展和应用。

Web3 新手系列:现在升级 @solana/web3.js 2.x 开启函数式编程

此页面可能包含第三方内容,仅供参考(非陈述/保证),不应被视为 Gate 认可其观点表述,也不得被视为财务或专业建议。详见声明
  • 赞赏
  • 3
  • 分享
评论
0/400
SoliditySlayervip
· 11小时前
这能提升多少tps呀
回复0
GateUser-aa7df71evip
· 11小时前
solana这波要起飞了吧
回复0
GateUser-e87b21eevip
· 11小时前
更新后开发轻松多了!
回复0
交易,随时随地
qrCode
扫码下载 Gate APP
社群列表
简体中文
  • 简体中文
  • English
  • Tiếng Việt
  • 繁體中文
  • Español
  • Русский
  • Français (Afrique)
  • Português (Portugal)
  • Bahasa Indonesia
  • 日本語
  • بالعربية
  • Українська
  • Português (Brasil)