• Sui提供dApp Kit 助力快速构建React Apps和dApps


    近日,Mysten Labs推出了dApp Kit,这是一个全新的解决方案,可用于在Sui上开发React应用程序和去中心化应用程序(dApps)。@mysten/dapp-kit是专门为React定制的全新SDK,旨在简化诸如连接钱包、签署交易和从RPC节点获取数据等重要任务。dApp Kit提供了可主题化的预构建组件,以简化钱包交互,还提供了更低级别的hooks和实用工具,以简化创建自定义组件。

    dApp kit是从Mysten Labs的经验中提炼出的,旨在让每个人更容易地开始构建dApps。事实上,Mysten Labs正在开始在所有自己的dApps中使用dApp kit。从Sui Explorer到Sui Wallet,他们构建的每个app都使用了dApp kit。我们才刚刚开始,但很高兴分享这个工具包,并帮助更多的开发者使用它!

    有关dApp Kit的详细介绍,请查看完整文档。本文,我们将向您介绍如何在React项目中设置dApp Kit。

    第一步:安装

    要开始使用dApp Kit,首先需要安装它以及react-query:

    npm install - save @mysten/dapp-kit @mysten/sui.js @tanstack/react-query

    安装完成后,您需要在应用程序中设置一些提供程序,以确保dApp Kit能够正常运行:

    1. import '@mysten/dapp-kit/dist/index.css';
    2. import { SuiClientProvider, WalletProvider } from '@mysten/dapp-kit';
    3. import { getFullnodeUrl } from '@mysten/sui.js/client';
    4. import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
    5. const queryClient = new QueryClient();
    6. const networks = {
    7. localnet: { url: getFullnodeUrl('localnet') },
    8. devnet: { url: getFullnodeUrl('devnet') },
    9. testnet: { url: getFullnodeUrl('testnet') },
    10. mainnet: { url: getFullnodeUrl('mainnet') },
    11. };
    12. ReactDOM.createRoot(document.getElementById('root')!).render(
    13. <QueryClientProvider client={queryClient}>
    14. <SuiClientProvider networks={networks} defaultNetwork="devnet">
    15. <WalletProvider>
    16. <App />
    17. </WalletProvider>
    18. </SuiClientProvider>
    19. </QueryClientProvider>,
    20. );

    在这段代码中,您会:

    • 导入必要的dApp Kit CSS以正确渲染组件
    • 设置一个react-query提供程序,用于管理dApp Kit发出的请求的状态
    • 初始化SuiClientProvider,它提供了SuiClient的实例并管理连接的网络
    • 配置WalletProvider,负责管理钱包连接

    现在,app已经正确设置,您可以开始使用dApp Kit的功能。

    第二步:连接钱包

    要让用户能够将他们的Sui钱包连接到dApp,您可以轻松地添加一个ConnectButton:

    1. import { ConnectButton } from '@mysten/dapp-kit';
    2. function App() {
    3. return (
    4. <div>
    5. <nav>
    6. <ConnectButton />
    7. </nav>
    8. <section>Hello, world</section>
    9. </div>
    10. );
    11. }

    这段代码将渲染一个按钮,点击它会打开一个模态框,提示用户连接他们的钱包。一旦连接成功,用户将看到他们已连接的钱包,并有选项再次断开连接。

    第三步:管理钱包状态

    dApp Kit提供了许多用于管理钱包状态的hooks。例如,useCurrentWallet允许您获取有关用户已连接账户的信息:

    1. import { ConnectButton, useCurrentAccount } from '@mysten/dapp-kit';
    2. function App() {
    3. const account = useCurrentAccount();
    4. return (
    5. <div>
    6. <nav>
    7. <ConnectButton />
    8. </nav>
    9. <section>{account ? 'No wallet connected' : `Your address is ${account.address}`}</section>
    10. </div>
    11. );
    12. }

    这使您能够根据用户的钱包状态显示相关信息。

    第四步:获取数据

    dApp Kit还为当前连接的用户提供了数据获取功能。可以使用useSuiClientQuery来调用RPC。您可以使用getOwnedObjects来访问并显示已连接账户拥有的对象列表:

    1. import { ConnectButton, useCurrentAccount } from '@mysten/dapp-kit';
    2. function App() {
    3. const account = useCurrentAccount();
    4. return (
    5. <div>
    6. <nav>
    7. <ConnectButton />
    8. </nav>
    9. <section>{account ? 'No wallet connected' : <OwnedObjects />}</section>
    10. </div>
    11. );
    12. }
    13. export function OwnedObjects() {
    14. const account = useCurrentAccount()!;
    15. const { data } = useSuiClientQuery('getOwnedObjects', { owner: account.address });
    16. return (
    17. <ul>
    18. {data.data.map((object) => (
    19. <li key={object.data?.objectId}>{object.data?.objectId}</li>
    20. ))}
    21. </ul>
    22. );
    23. }

    您可以在文档中了解更多关于进行RPC可调用的hooks信息。

    第五步:构建交易

    许多dApp需要创建和签署交易区块的能力。dApp Kit通过useSignAndExecuteTransactionBlock hook简化了这个过程。让我们创建一个按钮,将SUI发送到预定义的地址:

    1. import { signAndExecuteTransactionBlock } from '@mysten/dapp-kit';
    2. import { TransactionBlock } from '@mysten/sui.js/transactions';
    3. export function SendSui() {
    4. const { mutateAsync: signAndExecuteTransactionBlock } = useSignAndExecuteTransactionBlock();
    5. function sendMessage() {
    6. const txb = new TransactionBlock();
    7. const coin = txb.splitCoins(txb.gas, [10]);
    8. txb.transferObjects([coin], 'Ox...');
    9. signAndExecuteTransactionBlock({
    10. transactionBlock: txb,
    11. }).then(async (result) => {
    12. alert('Sui sent successfully');
    13. });
    14. }
    15. return <button onClick={() => sendMessage()}>Send me Sui!</button>;
    16. }

    当按下按钮时,它将:

    • 创建一个新的TransactionBlock
    • 添加一个splitCoins交易,将SUI从gas coin拆分成一个新的coin
    • 添加一个新的transferObject交易,将新coin转移到另一个地址
    • 使用连接的钱包签署和执行TransactionBlock
    • 触发一个alert,让您知道交易已执行完毕

    更多功能

    dApp Kit还有许多其他功能,可帮助您快速轻松地构建dApps。要了解更多详细信息和高级功能,请浏览完整文档

    有兴趣为Sui Blog做出贡献吗?欢迎填写此表格


    关于 Sui Network

    Sui是基于第一原理重新设计和构建而成的L1公有链,旨在为创作者和开发者提供能够承载Web3中下一个十亿用户的开发平台。Sui上的应用基于Move智能合约语言,并具有水平可扩展性,让开发者能够快速且低成本支持广泛的应用开发。获取更多信息:https://linktr.ee/sui_apac

    官网英文Twitter中文TwitterDiscord英文电报群中文电报群

  • 相关阅读:
    LeetCode 1553 吃掉N个橘子的最少天数
    【亚马逊云科技产品测评】活动征文|AWS EC2 部署Echarts大屏展示项目
    并查集介绍和基于并查集解决问题——LeetCode 952 按公因数计算最大组件大小
    攻防世界题目练习——Web引导模式(二)
    初始MySQL
    前端面试话术集锦第 14 篇:高频考点(React常考基础知识点)
    验证k8s中HPA功能及测试
    神经网络案例编程实战
    rocky8安装docker步骤
    uni-app 微信小程序支付/公众号支付/h5支付宝/h5微信/支付宝app支付/微信app支付
  • 原文地址:https://blog.csdn.net/Sui_Network/article/details/133990858