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.05%
查看原文
此頁面可能包含第三方內容,僅供參考(非陳述或保證),不應被視為 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)