💙 Gate广场 #Gate品牌蓝创作挑战# 💙
用Gate品牌蓝,描绘你的无限可能!
📅 活动时间
2025年8月11日 — 8月20日
🎯 活动玩法
1. 在 Gate广场 发布原创内容(图片 / 视频 / 手绘 / 数字创作等),需包含 Gate品牌蓝 或 Gate Logo 元素。
2. 帖子标题或正文必须包含标签: #Gate品牌蓝创作挑战# 。
3. 内容中需附上一句对Gate的祝福或寄语(例如:“祝Gate交易所越办越好,蓝色永恒!”)。
4. 内容需为原创且符合社区规范,禁止抄袭或搬运。
🎁 奖励设置
一等奖(1名):Gate × Redbull 联名赛车拼装套装
二等奖(3名):Gate品牌卫衣
三等奖(5名):Gate品牌足球
备注:若无法邮寄,将统一替换为合约体验券:一等奖 $200、二等奖 $100、三等奖 $50。
🏆 评选规则
官方将综合以下维度评分:
创意表现(40%):主题契合度、创意独特性
内容质量(30%):画面精美度、叙述完整性
社区互动度(30%):点赞、评论及转发等数据
Solana Web3.js 2.x版本重大升级:功能拆分与零依赖提升性能
Solana Web3.js 2.x 版本:功能丰富的 JavaScript 库重大升级
Solana Web3.js 作为一个功能强大的 JavaScript 库,在 11 月正式推出了 2.x 版本。相较于 1.x,新版本带来了诸多重大变化,本文将对其主要更新进行概述。
尽管 2.x 版本刚刚发布,目前使用量不高,许多广泛使用的库尚未迁移,但了解这些变化对未来的迁移工作至关重要。
版本比较
不可否认,旧版本在使用上更为简单直接。1.x 版本仅包含一个 @solana/web3.js 包,内含所有功能。它基于类的设计,封装了大量常用操作。例如,Connection 类提供了数十种方法,几乎涵盖了开发者所需的全部功能。此外,Solana cookbook 中丰富的示例代码为开发者提供了极大便利。
然而,这种设计也带来了一些问题。尽管开发者实际使用的功能可能只占很小一部分,但整个代码库都会被下载到用户设备上,由于库的代码量庞大,这可能会导致一定的加载延迟。
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("");
当调用 sendAndConfirmTransaction 发送交易时,会自动发起 HTTPS 请求,并建立 WSS 连接订阅交易状态,在交易确认后返回交易哈希。
密钥对处理
公钥和私钥相关的处理也发生了重大变化。1.x 版本中常用的 Keypair 和 PublicKey 类不再存在,被一系列函数所取代。
例如,现在可以使用 await generateKeyPair() 生成密钥对,而不是之前的 Keypair.generate()。
值得注意的是,新的 generateKeyPair 返回一个 Promise,而不是直接返回密钥对。这是因为新实现尽可能利用了 JavaScript 的 Web Crypto API,使用了原生的 Ed25519 实现。Web Crypto API 的许多方法都是异步的。不过,对于熟悉 Promise 的现代 JavaScript 开发者来说,这种变化并不难以接受。
交易发送
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/web3.js"; import { getTransferSolInstruction } from "@solana/system-program";
const transaction = pipe( createTransaction({ version: 0 }), addInstruction(getTransferSolInstruction({ fromPubkey: sender, toPubkey: recipient, lamports: amount })) );
const signature = await rpc.sendTransaction(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 网络进行交互,有助于推动该平台的采用和发展。尽管目前还处于早期阶段,但随着更多项目的迁移和社区的适应,相信 2.x 版本将在未来发挥更大的作用。