Solana Web3.js 2.x:模块化设计带来性能提升与开发挑战

Solana Web3.js 2.x:革新与挑战并存

Solana Web3.js 2.x 版本于今年 11 月正式发布,相较于 1.x 版本,新版本带来了显著的变化。尽管目前 2.x 版本的使用率仍不高,许多广泛使用的库尚未迁移,但了解这些变化对未来的开发工作至关重要。

版本对比

1.x 版本以其简洁性著称,仅需引入单一包 @solana/web3.js 即可。它基于类的设计,如 Connection 类,封装了大量常用操作,为开发者提供了全面的功能覆盖。然而,这种设计也带来了一个问题:即使开发者只使用少量功能,整个庞大的代码库也会被下载到用户设备上。

相比之下,2.x 版本采取了模块化的方法,将代码库拆分为多个小型模块,如 @solana/accounts、@solana/codecs 等。新版本放弃了基于类的实现,转而采用单个函数的方式,这有助于 JavaScript 代码构建时的优化。未使用的代码将被删除,不会被下载到用户设备上。据官方统计,使用新版本的去中心化应用(DApp)通常可以实现约 30% 的代码体积优化,对于仅使用少量功能的应用,优化比例可能更高。

这种改变对 Solana 团队的文档质量提出了更高要求。如何帮助开发者快速定位所需功能成为一个关键问题。目前,新版本的包名具有良好的语义性,这在一定程度上降低了开发者的迁移难度。

然而,由于 2.x 版本刚刚发布,许多项目尚未进行迁移。相关文档和示例也相对有限,特别是在涉及运行时内置功能的使用说明上存在不足,这可能会给开发者带来一些困扰。

2.x 版本的另一个重要特点是零依赖。这一特性对提高安全性具有重要意义,尤其是考虑到今年 12 月初发生在 @solana/web3.js 1.95.5 和 1.95.6 版本上的供应链攻击。开发团队决定更多地利用原生功能,减少外部依赖和 Polyfills 的使用,以降低安全风险。

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

重要变更点

连接方式

2.x 版本采用了更加函数式的方法来处理连接。新版本不再依赖 Connection 类,而是通过函数式的方式来配置 RPC 请求地址并创建请求发送器。

密钥对处理

在密钥对管理方面,2.x 版本也进行了重大改变。原先的 Keypair 和 PublicKey 类被一系列函数所取代。例如,现在使用 await generateKeyPair() 来生成密钥对,而不是之前的 Keypair.generate()。新的实现更多地利用了 JavaScript 的 Web Crypto API,采用原生的 Ed25519 实现,这导致了一些方法变为异步操作。

交易发送

2.x 版本废弃了 Transaction 和 VersionedTransaction 类,同时移除了 System Program 相关的方法。开发者现在需要从其他地方引入这些功能,例如使用 @solana-program/system 中的 getTransferSolInstruction 函数来实现转账指令。

新版本提供了函数式编程中常用的 pipe 形式,使得交易的构建和发送更加灵活和可定制。交易不再通过 Connection 发起,而是通过自定义的 RPC Provider 生成特定函数来完成。这种方式虽然增加了一些代码量,但提高了可定制性。

React 支持

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

总结

Solana Web3.js 2.x 版本的发布展现了开发团队对持续改进的承诺。新版本为开发者提供了更高效、灵活和可定制的 Solana 网络交互方式,有望推动该平台的进一步发展和应用。尽管目前面临一些挑战,但随着生态系统的逐步适应,2.x 版本有望成为 Solana 开发的新标准。

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

SOL2.46%
此页面可能包含第三方内容,仅供参考(非陈述/保证),不应被视为 Gate 认可其观点表述,也不得被视为财务或专业建议。详见声明
  • 赞赏
  • 2
  • 分享
评论
0/400
screenshot_gainsvip
· 07-11 09:02
旧版封装狠美 但太臃肿了
回复0
无聊猿反抗军vip
· 07-09 10:01
模块化好评 体积小到离谱
回复0
交易,随时随地
qrCode
扫码下载 Gate APP
社群列表
简体中文
  • 简体中文
  • English
  • Tiếng Việt
  • 繁體中文
  • Español
  • Русский
  • Français (Afrique)
  • Português (Portugal)
  • Bahasa Indonesia
  • 日本語
  • بالعربية
  • Українська
  • Português (Brasil)