0基础从前端到Web3 —— Mine Clearance Frontend(一)

2024-05-24 16:44

本文主要是介绍0基础从前端到Web3 —— Mine Clearance Frontend(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

初始化项目以及通过dapp-kit连接钱包的部分就不再赘述,具体可以点击查看,如果篇幅当中遇到了一些未添加的依赖项,直接通过pnpm add -D <name>一般都可以解决。

一:链上网络切换

这里提供一个最简单的切换方式,不需要放置下拉框,也不需要添加任何其它更多的设置,只需要在调用SuiClientProvider的时候增加一个参数onNetworkChange={(network) => setNetwork(network)},它的作用是当Sui钱包插件改变链上网络的时候触发setNetwork方法,并将新的链上网络传入设置。

function App() {const queryClient = new QueryClient();const [network, setNetwork] = React.useState("testnet");const networks = {testnet: { url: getFullnodeUrl('testnet') },mainnet: { url: getFullnodeUrl('mainnet') },};return (<div><QueryClientProvider client={queryClient}><SuiClientProvider networks={networks} network={network as keyof typeof networks} onNetworkChange={(network) => setNetwork(network)}><WalletProvider><div className='ConnectButton'><ConnectButton /></div><MineClearance /><FeedBack /></WalletProvider></SuiClientProvider></QueryClientProvider></div>);
}

二:游戏区域

首先是一个开始游戏的按钮,它的运行逻辑要在连接钱包之后,因为后面与链上的交互都需要事先明确“我是谁”。

function MineClearance() {const account = useCurrentAccount();const StartGame = () => {document.getElementById('NotConnect')!.hidden = true;if (!account) {document.getElementById('NotConnect')!.hidden = false;return;}// console.log("Connected");return;};return (<div className='Game'><div className='StartButton'><Button variant="contained" onClick={StartGame}>Game</Button><br></br><i id="NotConnect" hidden={true}>Please Connect First!!!</i></div><div id='Checkerboard'><DrawCheckerboard /></div></div>);
}

其次我们来考虑扫雷区域该如何进行描绘,很自然联想到,它是由一个又一个小方块依次拼接而成的,而mui正好又提供了一系列的ButtonGroup,所以问题就简化成了如何通过循环进行处理这些个按钮,包括放置、点击以及后续得到反馈后实时更改按钮状态等等。
本篇只涉及放置以及最基本的点击逻辑,而链上调用以及反馈信息处理等部分将留到下一篇文章。

function DrawCheckerboard() {const clickBoard = (event: any) => {const r = event.target.getAttribute('button-key')const l = event.target.parentElement.getAttribute('button-key');console.log(`(${r}, ${l})`);let str1 = event.currentTarget.innerHTML.split('<', 1)[0];const str2 = event.currentTarget.innerHTML.substring(str1.length);str1 = str1 == "x" ? "1" : "x";const str = str1.concat(str2);console.log(str);event.currentTarget.innerHTML = str;event.target.disabled = true;HiddenFeedBack();ShowFeedBack("circular_progress");// ShowFeedBack("success_alert");// ShowFeedBack("encourage_alert");// ShowFeedBack("failure_alert");}const childboard = [];let i = 1;while (i <= MaxRow) {childboard.push(<Button key={i} button-key={i} size="large" onClick={clickBoard} sx={{width: "1px"}}>&nbsp;</Button>);i += 1;}const checkerboard = [];let j = 1;while (j <= MaxList) {checkerboard.push(<ButtonGroup orientation='vertical' aria-label='Vertical button group' variant='outlined' key={j} button-key={j}>{childboard}</ButtonGroup>);j += 1;}return (<Box>{checkerboard}</Box>);
}

三:提示信息

mui提供了加载等待、成功失败提示等ui选择,我们直接选取其中的一些进行调用,目的是当后续实现了链上调用后的信息反馈,包括但不限于游戏成功、游戏失败等提示信息。

这些信息出现的位置应当是游戏区域下方,而且若非特殊需求,应当一次只出现一个,其它的都应该隐藏,这里就需要令写函数对这系列的<div>标签进行统一管理。

function FeedBack() {return (<div className='FeedBack'><div id="circular_progress" hidden={true}><CircularProgress /></div><div id="success_alert" className='SuccessAlert' hidden={true}><Alert variant="outlined" severity="success">Congratulations on your successful mine clearance!</Alert></div><div id="encourage_alert" className='EncourageAlert' hidden={true}><Alert variant="outlined" severity="info">Fortunately you didn't touch a landmine, please consider your next step!</Alert></div><div id="failure_alert" className='FailureAlert' hidden={true}><Alert variant="outlined" severity="error">Unfortunately, the minesweeper failed!</Alert></div></div>);
}function ShowFeedBack(id: string) {// document.getElementById(id)!.hidden = false;if (id == "circular_progress")document.getElementById(id)!.hidden = false;elsedocument.getElementById(id)!.style.display = "inline-flex";
}function HiddenFeedBack() {document.getElementById("circular_progress")!.hidden = true;// document.getElementById("success_alert")!.hidden = true;// document.getElementById("encourage_alert")!.hidden = true;// document.getElementById("failure_alert")!.hidden = true;document.getElementById("success_alert")!.style.display = "none";document.getElementById("encourage_alert")!.style.display = "none";document.getElementById("failure_alert")!.style.display = "none";
}

这里的实现方式多样,呈现的只是其中一种也绝非是最优解,毕竟自己看着都有点累赘(后面可能会视情况更改)。

四:其它

完整代码可以点击查看,下面是几张实际运行图。

在这里插入图片描述

在这里插入图片描述

五:加入组织,共同进步!

  • Sui 中文开发群(TG)
  • M o v e \mathit{Move} Move 语言学习交流群: 79489587

这篇关于0基础从前端到Web3 —— Mine Clearance Frontend(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/998963

相关文章

Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

《Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)》文章介绍了如何使用dhtmlx-gantt组件来实现公司的甘特图需求,并提供了一个简单的Vue组件示例,文章还分享了一... 目录一、首先 npm 安装插件二、创建一个vue组件三、业务页面内 引用自定义组件:四、dhtmlx

Vue ElementUI中Upload组件批量上传的实现代码

《VueElementUI中Upload组件批量上传的实现代码》ElementUI中Upload组件批量上传通过获取upload组件的DOM、文件、上传地址和数据,封装uploadFiles方法,使... ElementUI中Upload组件如何批量上传首先就是upload组件 <el-upl

前端知识点之Javascript选择输入框confirm用法

《前端知识点之Javascript选择输入框confirm用法》:本文主要介绍JavaScript中的confirm方法的基本用法、功能特点、注意事项及常见用途,文中通过代码介绍的非常详细,对大家... 目录1. 基本用法2. 功能特点①阻塞行为:confirm 对话框会阻塞脚本的执行,直到用户作出选择。②

如何使用CSS3实现波浪式图片墙

《如何使用CSS3实现波浪式图片墙》:本文主要介绍了如何使用CSS3的transform属性和动画技巧实现波浪式图片墙,通过设置图片的垂直偏移量,并使用动画使其周期性地改变位置,可以创建出动态且具有波浪效果的图片墙,同时,还强调了响应式设计的重要性,以确保图片墙在不同设备上都能良好显示,详细内容请阅读本文,希望能对你有所帮助...

CSS3 最强二维布局系统之Grid 网格布局

《CSS3最强二维布局系统之Grid网格布局》CS3的Grid网格布局是目前最强的二维布局系统,可以同时对列和行进行处理,将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局,本文介... 深入学习 css3 目前最强大的布局系统 Grid 网格布局Grid 网格布局的基本认识Grid 网

HTML5中下拉框<select>标签的属性和样式详解

《HTML5中下拉框<select>标签的属性和样式详解》在HTML5中,下拉框(select标签)作为表单的重要组成部分,为用户提供了一个从预定义选项中选择值的方式,本文将深入探讨select标签的... 在html5中,下拉框(<select>标签)作为表单的重要组成部分,为用户提供了一个从预定义选项中

前端 CSS 动态设置样式::class、:style 等技巧(推荐)

《前端CSS动态设置样式::class、:style等技巧(推荐)》:本文主要介绍了Vue.js中动态绑定类名和内联样式的两种方法:对象语法和数组语法,通过对象语法,可以根据条件动态切换类名或样式;通过数组语法,可以同时绑定多个类名或样式,此外,还可以结合计算属性来生成复杂的类名或样式对象,详细内容请阅读本文,希望能对你有所帮助...

禁止HTML页面滚动的操作方法

《禁止HTML页面滚动的操作方法》:本文主要介绍了三种禁止HTML页面滚动的方法:通过CSS的overflow属性、使用JavaScript的滚动事件监听器以及使用CSS的position:fixed属性,每种方法都有其适用场景和优缺点,详细内容请阅读本文,希望能对你有所帮助... 在前端开发中,禁止htm

Vue3中的动态组件详解

《Vue3中的动态组件详解》本文介绍了Vue3中的动态组件,通过`component:is=动态组件名或组件对象/component`来实现根据条件动态渲染不同的组件,此外,还提到了使用`markRa... 目录vue3动态组件动态组件的基本使用第一种写法第二种写法性能优化解决方法总结Vue3动态组件动态

spring-boot-starter-thymeleaf加载外部html文件方式

《spring-boot-starter-thymeleaf加载外部html文件方式》本文介绍了在SpringMVC中使用Thymeleaf模板引擎加载外部HTML文件的方法,以及在SpringBoo... 目录1.Thymeleaf介绍2.springboot使用thymeleaf2.1.引入spring