当前位置: 首页 > news >正文

Web3 初学者的第一个实战项目:留言上链 DApp

目录

📌 项目简介:留言上链 DApp(MessageBoard DApp)

🧠 技术栈

🔶 1. Solidity 智能合约代码(MessageBoard.sol)

🔷 2. 前端代码(index.html + script.js)

📄 index.html

📜 script.js

💅 style.css

🧪 测试建议


📌 项目简介:留言上链 DApp(MessageBoard DApp)

  • 用户可以输入留言,点击按钮后信息将上链保存。

  • 展示所有用户的留言。

  • 使用以太坊测试网部署合约。


🧠 技术栈

  • Solidity(智能合约)

  • Ethers.js(前端与链交互)

  • HTML/CSS/JS(简单前端)

  • Remix + Metamask + 测试网(部署)

🔶 1. Solidity 智能合约代码(MessageBoard.sol)

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.18;contract MessageBoard {struct Message {address sender;string content;uint256 timestamp;}Message[] public messages;event NewMessage(address indexed sender, string content, uint256 timestamp);function postMessage(string calldata _content) public {messages.push(Message(msg.sender, _content, block.timestamp));emit NewMessage(msg.sender, _content, block.timestamp);}function getMessages() public view returns (Message[] memory) {return messages;}function getMessageCount() public view returns (uint256) {return messages.length;}
}

部署提示:使用 Remix IDE,连接 Metamask 钱包选择测试网(如 Sepolia),部署后复制合约地址。

🔷 2. 前端代码(index.html + script.js)

📄 index.html
<!DOCTYPE html>
<html lang="zh">
<head><meta charset="UTF-8" /><title>留言上链 DApp</title><script src="https://cdn.jsdelivr.net/npm/ethers/dist/ethers.min.js"></script><link rel="stylesheet" href="style.css" />
</head>
<body><h1>留言上链 DApp</h1><textarea id="messageInput" placeholder="请输入留言内容"></textarea><br /><button onclick="postMessage()">发送留言</button><button onclick="loadMessages()">刷新留言</button><div id="messageList"></div><script src="script.js"></script>
</body>
</html>
📜 script.js
const contractAddress = "你的合约地址";
const contractABI = [// 仅保留必要的 ABI 函数"function postMessage(string _content)","function getMessages() view returns (tuple(address sender, string content, uint256 timestamp)[])"
];let provider, signer, contract;async function init() {if (typeof window.ethereum !== 'undefined') {provider = new ethers.providers.Web3Provider(window.ethereum);await provider.send("eth_requestAccounts", []);signer = provider.getSigner();contract = new ethers.Contract(contractAddress, contractABI, signer);loadMessages();} else {alert("请安装 Metamask 插件");}
}async function postMessage() {const message = document.getElementById("messageInput").value;if (!message) return alert("请输入内容");const tx = await contract.postMessage(message);await tx.wait();alert("留言已上链!");loadMessages();
}async function loadMessages() {const messages = await contract.getMessages();const list = document.getElementById("messageList");list.innerHTML = "";messages.forEach((msg) => {const div = document.createElement("div");const time = new Date(msg.timestamp * 1000).toLocaleString();div.innerText = `🗨️ ${msg.content}\n👤 ${msg.sender}\n🕒 ${time}`;div.style.margin = "12px";list.appendChild(div);});
}window.onload = init;
💅 style.css
body {font-family: sans-serif;max-width: 600px;margin: 0 auto;padding: 20px;
}
textarea {width: 100%;height: 80px;margin-bottom: 10px;
}
button {margin-right: 10px;
}

🧪 测试建议

  1. 用 Remix 部署合约到 Sepolia 测试网。

  2. 在前端代码中替换 contractAddress

  3. 用浏览器打开 index.html 文件(确保开启 Metamask)。

  4. 输入留言并发送,刷新查看链上内容。

相关文章:

  • 质量保证计划,软件质量计划书,软件质量方案(word原件)
  • FHE 之 面向小白的引导(Bootstrapping)
  • 6.秒杀优化
  • HTTP:十三.HTTP日志
  • 数据库版本控制工具--flyway
  • CSDN 中 LaTeX 数学公式输入方法
  • 思考:(linux) tmux 超级终端快速入门的宏观思维
  • c++ using使用
  • 通信原理绪论
  • JDBC工具类的三个版本
  • 【python】json解析:invalid literal for int() with base 10: ‘\“\“‘“
  • 工厂节能新路径:精准节能的深度剖析
  • YOLO目标检测算法评估标准
  • C++STL——stack,queue
  • Python3(30) 正则表达式
  • 两数相加(2)
  • Profinet转CanOpen网关,打破协议壁垒的关键技术
  • 国内特殊车辆检测数据集VOC+YOLO格式4930张3类别
  • NVMe控制器IP设计之接口模块
  • Python核心编程深度解析:作用域、递归与匿名函数的工程实践
  • 阶跃星辰CEO姜大昕:追求智能上限仍是最重要的事,多模态的“GPT-4时刻”尚未到来
  • 中山大学人类学系原系主任冯家骏逝世,享年95岁
  • 气象干旱黄色预警继续:陕西西南部、河南西南部等地特旱
  • 苏东坡:人生就是哈哈哈哈哈
  • 国常会:研究深化国家级经济技术开发区改革创新有关举措等
  • 上汽享道出行完成13亿元C轮融资,已启动港股IPO计划