5. 使用 Truffle

使用 Truffle 在 ChainIDE 上快速搭建一个 dApp。

Consensys 宣布终止与 Truffle 和 Ganache 的合作关系以及和 HardHat 新的合作关系,更多详情

1. 打开 Sandbox

注:以 GIthub 方式登录 ChainIDE 后才可使用 Sandbox 功能。

打开 Sandbox,输入 truffle version 可查看当前 truffle 版本

2. 创建项目

你可以使用 truffle init 创建一个没有智能合约的裸项目,但对于那些初学者,你可以使用 Truffle Boxes 示例应用程序和项目模板。我们将使用 MetaCoin ,它创建一个可以在账户之间转移的代币。请注意,这与 ERC-20 不兼容。

  1. 下载 ("unbox") the MetaCoin box:

完成此操作后,您将拥有包含以下项目结构:

3. 探索项目

在文本编辑器中打开 contracts/MetaCoin.sol 文件。这是一个智能合约(用 Solidity 编写),用于创建 MetaCoin 代币。请注意,这也引用了同一目录中的另一个 Solidity 文件 contracts/ConvertLib.sol

打开 migrations/1_deploy_contracts.js 文件。此文件是迁移(部署)脚本。

打开 test/TestMetaCoin.sol 文件。这是一个用 Solidity 编写的测试文件,可确保您的合约按预期工作。

打开 test/metacoin.js 文件。这是一个用 JavaScript 编写的测试文件,它具有与上面的 Solidity 测试文件类似的功能。该测试也可以用 typescript 编写。

打开 truffle-config.js 文件。这是 Truffle 配置文件,用于设置网络信息和其他与项目相关的设置。该文件是空白的,但这没关系,因为我们将使用内置一些默认值的 Truffle 命令。

4. 测试

要运行所有测试,只需运行 truffle test 。因为 developmenttruffle-config.js 注释掉了, truffle test 所以会启动并关闭一个本地测试实例 ( ganache )。如果你想使用 ganache 更多的功能,您可以启动一个单独的实例,并在 truffle-config 中指定端口号。

您还可以通过调用 truffle test ./test/TestMetaCoin.soltruffle test ./test/metacoin.js 来单独运行每个测试。

5. 编译

如果只想编译,可以简单地运行 truffle compile

您将看到以下输出:

6. 使用 Truffle Develop 进行迁移

为了部署我们的智能合约,我们需要连接到区块链。Truffle有一个内置的个人区块链,可用于测试。该区块链是您系统的本地区块链,不与以太坊主网络交互。

您可以创建此区块链并使用 Truffle Develop 与之交互。

  1. 运行 Truffle Develop:

您将看到以下信息:

这显示了在与区块链交互时可以使用的十个帐户(及其私钥)。

  1. 在 Truffle Develop 提示符下,可以通过省略 truffle 前缀来运行 Truffle 命令。例如,若要在提示符下运行 truffle compile ,请键入 compile 。将编译的合约部署到区块链的命令是 truffle migrate 。默认情况下, truffle migrate 也会运行 truffle compile ,因此您只需执行以下操作:

您将看到以下输出:

这会显示已部署合约的交易 ID 和地址。它还包括成本摘要和实时状态更新。

7. 使用 Truffle Console 迁移

虽然 Truffle Develop 是一个多合一的个人区块链和控制台,但它启动了一个非常基本的 ganache 实例。您还可以使用应用程序来启动您的个人区块链,对于那些刚接触以太坊和区块链的人来说,这是一个更容易理解的工具,因为它预先显示了更多信息。

可以参考 使用 Ganache v7 在 ChainIDE 中运行 Ganache。下一步需要编辑 Truffle 配置文件以指向 Ganache 实例。

  1. 在文本编辑器中打开 truffle-config.js 。将内容替换为以下内容:

这将允许使用 Ganache 的默认连接参数进行连接。

  1. 保存并关闭该文件。

  2. 在终端上,将合约迁移到 Ganache 创建的区块链:

您将看到以下输出:

这会显示已部署合约的交易 ID 和地址。它还包括成本摘要和实时状态更新。

注意:您的交易ID和合约地址可能与上述不同。

  1. 要与合约交互,您可以使用 Truffle 控制台。Truffle 控制台类似于 Truffle Develop,不同之处在于它连接到现有的区块链(在本例中为 Ganache 生成的区块链)。

您将看到以下提示:

8. 与合约交互

通过以下方式使用控制台与合约交互:

注意:我们在这些示例中使用 web3.eth.getAccounts() ,它返回一个 promise,该 promise 解析为助记词生成的所有帐户的数组。因此,鉴于上面我们助记词生成的地址,指定 (await web3.eth.getAccounts())[0] 等价于地址 0x627306090abab3a6e1400e9345bc60c78a8bef57

从 Truffle v5 开始,控制台支持 async/await 函数,从而可以更轻松地与合约进行交互。

  • 首先建立已部署的 MetaCoin 合约实例和 Truffle 的内置区块链或 Ganache 创建的账户:

  • 查看部署合约的账户的 metacoin 余额:

  • 查看该余额的价值(请注意,合约将 metacoin 定义为价值 2 个以太币):

  • 将一些 metacoin 从一个帐户转移到另一个帐户:

  • 检查收到 metacoin 的账户余额:

  • 检查发送 metacoin 的账户余额:

9. 部署到主网、测试网等

如果要部署到备用网络,请考虑使用 Truffle Dashboard。只需调用 truffle dashboard --network dashboard 并部署、测试和运行控制台即可。

10. 继续学习

本快速入门介绍了 Truffle 项目生命周期的基础知识,但还有很多东西需要学习。请继续阅读 Truffle 官方文档Arbitrum Box

Last updated

Was this helpful?