Solana Web3.js 2.x發布:函數式編程與性能優化的重大升級

Solana Web3.js 2.x 版本:函數式編程的新篇章

Solana Web3.js 作爲一個功能豐富的 JavaScript 庫,在今年 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、@solana/signers、@solana/transactions 等。新版本放棄了基於類的實現,轉而採用單個函數的方式,這有利於 JavaScript 代碼構建時的優化。未使用的代碼會被刪除,實際上不會被下載到用戶設備上。據官方文檔統計,使用新版本的 DApp 通常能獲得 30% 的體積優化,如果只用到少量功能,優化比例可能更高。

這種變化對 Solana 團隊的文檔質量提出了更高要求。如何讓開發者快速找到所需功能成爲一個關鍵問題。目前看來,包名的語義性還不錯,從名稱上就能大致了解它們的用途,這在一定程度上降低了開發者遷移的難度。

由於剛發布不久,許多項目還未進行遷移。Solana Cookbook 上關於 2.x 版本的示例也較少。另外,新版本傾向於使用運行時內置功能(如生成密鑰對),但文檔中對這些部分的描述不足,導致某些地方開發者可能感到困惑。

2.x 版本的另一個重要特點是零依賴。這對許多用戶來說可能不太重要,但考慮到今年 12 月初發生在 @solana/web3.js 1.95.5 和 1.95.6 版本上的供應鏈攻擊,減少外部輸入和依賴可以顯著降低安全事件發生的可能性。隨着 2.x 版本的發布,Web3.js 的開發團隊決定更多地使用本機功能,取消外部依賴和 Polyfills 的引入。雖然未來可能會有變化,但目前 2.x 版本已經消除了所有外部依賴。

重要變更點

連接

在 1.x 版本中,Connection 類提供了大量方法。但其核心功能是通過配置 RPC 請求地址創建一個請求發送器,然後用它發送各種請求。

2.x 版本採用了更加函數式的方法:

javascript import { createSolanaRpc } from '@solana/web3.js';

const rpc = createSolanaRpc(');

// 使用 rpc 發送交易 const signature = await rpc.sendAndConfirmTransaction(transaction);

在這個新版本中,當我們調用 sendAndConfirmTransaction 發送交易時,它會自動發起 HTTPS 請求,並建立一個 WSS 連接來訂閱交易狀態,在交易被確認後返回交易哈希。

密鑰對

公鑰和私鑰相關的部分也有重大變化。1.x 版本中常用的 Keypair 和 PublicKey 類不再存在,被一些函數取代。

例如,現在可以使用 await generateKeyPair() 生成密鑰對,而不是之前的 Keypair.generate()。

值得注意的是,新的 generateKeyPair 返回一個 Promise,而不是直接返回密鑰對。這是因爲新的實現盡可能利用了 JavaScript 的 Web Crypto API,使用了原生的 Ed25519 實現。Web Crypto API 的許多方法都是異步的。不過,這種變化並非不可接受,在 2024 年即將結束的今天,JavaScript 開發者已經非常熟悉 Promise 了。

發送交易

1.x 版本的用戶應該很熟悉 Transaction 和 VersionedTransaction 這兩個類,它們之間的關係曾讓許多開發者感到困惑。

在 2.x 版本中,這兩個類不再存在。

舊版本中提供的 System Program 相關方法也不再存在,所以 SystemProgram 類上的靜態方法都需要從其他地方引入。

例如,transfer 指令現在需要調用 @solana-program/system 中的 getTransferSolInstruction 函數。

由於不再提供類,Web3.js 提供了函數式編程中常用的 pipe 形式。下面是使用 pipe 函數實現原本 1.x 版本轉帳功能的示例:

javascript import { pipe } from '@solana/functional'; import { getTransferSolInstruction } from '@solana/system-program'; import { createSolanaRpc } from '@solana/web3.js';

const rpc = createSolanaRpc(');

const transaction = pipe( createTransaction({ version: 0 }), addInstruction(getTransferSolInstruction({ from: senderPublicKey, to: recipientPublicKey, amount: transferAmount, })) );

const signature = await rpc.sendAndConfirmTransaction(transaction);

可以看出,交易不再通過 Connection 發起,而是通過我們定義的 RPC Provider 生成一個特定的函數,然後調用該函數來發起交易。相比 1.x 版本,代碼量有所增加,但優點是可定制性更強了。

交易通過 HTTPS RPC 發起,然後通過訂閱 WSS RPC 來確認交易結果。可以感受到新的方式非常依賴 WSS,相信未來 WSS 的應用將會越來越廣泛,這也對 RPC 供應商的服務穩定性提出了更高的要求。

React 支持

有趣的是,@solana/web3.js 項目中還包含了一個名爲 @solana/react 的庫,提供了一些 React Hook,內置了諸如 signIn 等功能。

總結

@solana/web3.js 2.x 版本的發布充分體現了 Solana 團隊對不斷發展和改進的承諾。它爲開發人員提供了一個高效、靈活、可定制的與 Solana 網路交互的方式,有助於推動該平台的採用和發展。

Web3 新手系列:現在升級 @solana/web3.js 2.x 開啓函數式編程

SOL0.97%
查看原文
此頁面可能包含第三方內容,僅供參考(非陳述或保證),不應被視為 Gate 認可其觀點表述,也不得被視為財務或專業建議。詳見聲明
  • 讚賞
  • 8
  • 轉發
  • 分享
留言
0/400
社区打杂人vip
· 9小時前
这咋迭代这么慢呢
回復0
治理提案狂vip
· 18小時前
有进步,但还不够radical
回復0
幽灵链忠实粉vip
· 08-09 07:05
2.0还是慢了 啥时候学会整天盯着版本升级
回復0
PanicSeller69vip
· 08-07 19:20
升级有啥用 不还得换库
回復0
MemeCoinSavanvip
· 08-07 07:47
基于af,solana在web3演进中证明了统计显著性,老实说
查看原文回復0
农场跳跃者vip
· 08-07 07:46
居然还在用1.x 啧啧
回復0
号角三声vip
· 08-07 07:45
开发党哪还等的及
回復0
ZkProofPuddingvip
· 08-07 07:43
真香~晚了半年才更新捏
回復0
交易,隨時隨地
qrCode
掃碼下載 Gate APP
社群列表
繁體中文
  • 简体中文
  • English
  • Tiếng Việt
  • 繁體中文
  • Español
  • Русский
  • Français (Afrique)
  • Português (Portugal)
  • Bahasa Indonesia
  • 日本語
  • بالعربية
  • Українська
  • Português (Brasil)