Scaffold-eth 快速上手 | Web3.0 dApp 开发(二)

开发新鲜人的第一个 dApp

前言

Scaffold-eth 是搭建以太坊上 dApp 的模板(Template),也是 dApp 优秀作品的集合,让开发人员可以大大提升开发效率,降低踩坑几率,是 web3.0 dApp 开发者的「入门神器」。

它包括如下组件:

  • hardhat: 用于运行本地网络、部署和测试智能合约。
  • React: 使用许多预制组件和hooks来构建前端。
  • Ant: 用于构建你的UI,可以轻松更改为Bootstrap或者其他库。
  • Surge: 发布你的应用。
  • Tenderly / The Graph / Etherscan / Infura / Blocknative 等等。
  • 支持 L2 / Sidechains。

极速部署

环境要求

Scafford Eth 基于 Node.js 环境,需要安装node.jsyarn

部署 Scaffold-eth 脚手架

  1. 获取项目源代码
git clone https://github.com/austintgriffith/scaffold-eth.git
  1. 打开三个命令行面板

TIPS:很多Terminal 终端都支持分屏操作。

image-20210924203810255

  1. 在第一个命令行面板里,启动 👷‍ Hardhat chain:
cd scaffold-eth
yarn install
yarn chain

在这里插入图片描述

  1. 在第二个命令行窗口里,部署 /scaffold-eth/packages/hardhat/contracts/ 下的合约。
cd scaffold-eth
yarn deploy

在这里插入图片描述

  1. 在第三个命令行窗口里 启动你的前端应用:
cd scaffold-eth
yarn start

在这里插入图片描述

主分支下的案例合约是一个存储/读取值的合约,你可以在 /scaffold-eth/packages/hardhat/contracts/下找到这个合约并修改这个新合约的内容然后重新部署。

TIPS:

如果你对其他的合约项目感兴趣,可以切换仓库的分支部署不同的dapp服务。 可以切换的案例分支 比如nft的案例分支 https://github.com/scaffold-eth/scaffold-eth/tree/simple-nft-example

应用体验

回到刚才的话题,这时候 我们合约部署了,前端和本地测试链都启动了。 在这里我们先贴一下 我们刚才deploy的合约内容。

pragma solidity >=0.8.0 <0.9.0;
//SPDX-License-Identifier: MIT

import "hardhat/console.sol";
//import "@openzeppelin/contracts/access/Ownable.sol"; //https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/access/Ownable.sol

contract YourContract {

  //event SetPurpose(address sender, string purpose);

  string public purpose = "Building Unstoppable Apps!!!";

  constructor() {
    // what should we do on deploy?
  }

  // 存储 purpose 变量
  function setPurpose(string memory newPurpose) public {
      purpose = newPurpose;
      console.log(msg.sender,"set purpose to",purpose);
      //emit SetPurpose(msg.sender, purpose);
  }
}

合约里设置了一个 public 的string 变量 purpose,这个purpose的默认值是“Building……",也提供了一个setPurpose方法 可以通过这个方法去修改purpose的内容。

现在我们访问前端服务http://localhost:3000在这里插入图片描述

  1. 给账户申请测试币 在这里插入图片描述 在这里插入图片描述 在这里插入图片描述
  2. 调用合约方法。 因为调用方法需要耗费gas,所以一定得申请测试代币。 在这里插入图片描述 在这里插入图片描述 在这里插入图片描述 可见purpose的值成功修改,我们账户由于调用方法的时候消耗了gas费所以这里的余额也不在是1这个整数。

总结

我们可以通过scaffold-eth这个脚手架快速构架我们的Dapp应用,在hardhat里它不光可以deploy在本地测试网,你可以选择网络地址,可以将你的合约部署在任何的网络里。 至此我们的scaffold-eth快速体验就到这里了。

关于作者

<div align=center><a href="https://blog.csdn.net/qq_19381989" target="_blank"><img src="https://img-blog.csdnimg.cn/a7acf46695554b99a9483daf8423ab2d.png" width="40%" /></a></div>

简介:微芒社区上贸大 SIG 核心成员。

作者的联系方式:

微信:thf056 qq:1290017556 邮箱:1290017556@qq.com

你也可以通过 <strong><a href="https://github.com/99kies" target="_blank">github</a></strong> | <strong><a href="https://blog.csdn.net/qq_19381989" target="_blank">csdn</a></strong>关注我的动态

Github:https://github.com/99kies

CSDN:https://blog.csdn.net/qq_19381989

本文参与登链社区写作激励计划 ,好文好收益,欢迎正在阅读的你也加入。

0 条评论

请先 登录 后评论
李大狗
李大狗

上海对外经贸大学区块链研究中心副主任

51 篇文章, 5850 学分