”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 免费接龙

免费接龙

发布于2024-11-06
浏览:421

很久以前,在同一个星系中,我开始尝试制作 Freecell,作为学习 Angular 1.3 的一种方式。

我已经走了这么远,然后我就被其他事情分散了注意力,就像副项目一样。

我最近有一些空闲时间(我知道,我也没想到),所以我想我应该再试一次。

我基本上是从头开始,因为我对 Angular 1.3 不再感兴趣,如果我需要一个框架,我倾向于使用 VueJS 来处理我的 Web 内容。

要查看结果,请访问 github.io:单击此处玩空当接龙!

自从我十五年前学习 WPF 以来,我就非常喜欢 MVVM 编程风格。 VueJS 非常容易地允许这种风格,甚至对其进行改进,而不需要显式事件来更新 UI。

这意味着游戏逻辑与视图逻辑完全分离,这使得编写这个游戏变得轻而易举。

这并不全是飞机航行,因为出于某种原因,我决定将卡片存储在二维锯齿状阵列中。这不是一个糟糕的主意,但每个内部数组都是一列,所以当我试图让卡片在 CSS 网格中正确布局时,我不能只迭代外部数组,然后迭代内部数组,例如

因为这会将列排列为行。所以我不得不使用索引(为什么 VueJS 不从 0 开始???)而不是对象并在内部循环上循环外部数组:

我认为我做出的另外两个糟糕的设计决策是实现自动完成,并使点击处理程序只是游戏中的一个功能(即模型),而不是在视图中,并让视图确定哪个过程采取的行动。

让游戏决定玩家的意思(即选择一张牌(或一堆牌)、将牌放在另一堆牌上或取消选择牌)导致了一些意大利面条式代码,我可能想在以后重构这些代码。

最初我不想实现自动完成,因为我不想考虑逻辑。但在没有它玩了几场游戏后,我对将每张卡敲入主行感到非常无聊,以至于我觉得有必要实施它。

我应该坚持我的立场,因为这很糟糕。这是一大堆代码,最初导致了一堆错误和令人头疼的问题。它甚至不是全自动的。另一方面,现在我几乎不需要做那么多的敲击。

我确实坚持不让卡片拖放,因为我制作这个主要是为了在我的手机和平板电脑上玩,所以从用户体验角度来说,点击到位要容易得多(至少是我的用户体验, ymmv).

总的来说,我对结果感到满意,即使有一些错误挥之不去。

Free freecell 梅伦 / 空当接龙

纸牌游戏 Free Cell 的实现

版本声明 本文转载于:https://dev.to/mellen/free-freecell-4kb2?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何使用 PHP 为图像添加水印?
    如何使用 PHP 为图像添加水印?
    使用 PHP 向图像添加水印如果您正在使用允许用户上传图像的网站,则可能需要添加这些图像的水印,以防止未经授权的使用。添加水印可确保您的徽标或品牌在每个上传的图像上都可见。以下是如何在 PHP 中实现此目的:使用 PHP 函数PHP 手册提供了使用以下函数的综合示例:imagecreatefromp...
    编程 发布于2024-11-06
  • 如何抑制 Tensorflow 调试输出?
    如何抑制 Tensorflow 调试输出?
    抑制Tensorflow调试信息Tensorflow可能会在初始化时在终端中显示调试信息,包括加载的库和发现的设备。虽然此信息对于调试目的很有用,但它也会使控制台混乱并使跟踪重要消息变得困难。要禁用此调试信息,您可以使用 os.environ 模块:import os os.environ['TF_...
    编程 发布于2024-11-06
  • 如何确定我的 MySQL 查询是否利用了索引?
    如何确定我的 MySQL 查询是否利用了索引?
    识别 MySQL 索引的性能优化 MySQL 查询时,评估索引的有效性至关重要。获取索引性能指标要确定您的查询是否使用索引,请执行以下查询:EXPLAIN EXTENDED SELECT col1, col2, col3, COUNT(1) FROM table_name WHERE col1 ...
    编程 发布于2024-11-06
  • 如何更改 WAMP/MySQL 中错误消息的语言?
    如何更改 WAMP/MySQL 中错误消息的语言?
    WAMP/MySQL 中的语言错误许多用户都遇到过 WAMP/MySQL 中的错误未以正确的语言显示的问题。多次重新安装WAMP并搜索大量资源后,该问题仍然存在。要解决此问题,需要修改my.ini文件。修改my.ini文件找到行:# Change your locale here ! lc-mess...
    编程 发布于2024-11-06
  • Item - 返回空集合或数组而不是 null
    Item - 返回空集合或数组而不是 null
    不返回 null: 返回 null 代替空集合或数组的方法需要额外的客户端处理以避免异常。 null 问题: 客户端需要添加冗余检查(如果要检查null)。 这些检查中的遗漏可能会被忽视,从而导致错误。 返回集合或数组的方法很难实现。 反对 null 的参数: 不要担心分配空集合或数组的性能,除非...
    编程 发布于2024-11-06
  • 节点 JS || Epress js ||作者:穆尼塞卡·乌达瓦拉帕蒂
    节点 JS || Epress js ||作者:穆尼塞卡·乌达瓦拉帕蒂
    Express js 编写简单的express js应用程序 npm 初始化 npm 安装 Express const express=require('expreass'); const app=express(); app.use('/',(req,res,next)=>{ rse...
    编程 发布于2024-11-06
  • 嵌套括号可以在没有递归或平衡组的情况下匹配吗?
    嵌套括号可以在没有递归或平衡组的情况下匹配吗?
    在没有递归或平衡组的情况下匹配嵌套括号使用正则表达式匹配嵌套括号可能具有挑战性,特别是在像 Java 这样的语言中,其中递归且不支持平衡组。幸运的是,使用前向引用确实可以克服此限制。匹配外部组以下正则表达式 [1] 匹配外部组括号而不对深度施加限制:(?=\()(?:(?=.*?\((?!.*?\1...
    编程 发布于2024-11-06
  • 使用 TDD 方法论和 PostgreSQL 使用 Django 构建完整博客应用程序的指南(部分安全用户身份验证)
    使用 TDD 方法论和 PostgreSQL 使用 Django 构建完整博客应用程序的指南(部分安全用户身份验证)
    Welcome back, everyone! In the previous part, we established a secure user registration process for our Django blog application. However, after succes...
    编程 发布于2024-11-06
  • 如何编写更好的 CSS
    如何编写更好的 CSS
    为了为网站样式编写更好的CSS,您必须首先学习三件事,即响应式设计,您的代码可维护和可扩展,并且具有执行性。 响应式设计就是要确保您的网站在每种可能的屏幕尺寸上都具有完美的外观和行为。随着屏幕尺寸的不断增加,响应式设计是每个前端开发人员必须学习和掌握的基本概念。 您编写的代码必须以其他开发人员也可以...
    编程 发布于2024-11-06
  • 解锁 JavaScript 的超能力:变量的魔力
    解锁 JavaScript 的超能力:变量的魔力
    从今天开始,我们将发现一个编程的世界。 你拥有超能力的世界。是的,你没看错,超能力。如果不是超能力,那又是什么?使用 JavaScript,您可以让物体飞、移动、消失、改变颜色,并在数英里之外看到您的朋友,而这只是可能的一小部分。是的,一切都在你的屏幕上,但仍然非常令人兴奋。 像任何超级英雄一样,你...
    编程 发布于2024-11-06
  • 如何在 PHP 中访问和检索通过 POST 发送的表单变量?
    如何在 PHP 中访问和检索通过 POST 发送的表单变量?
    如何检索通过 POST 传输的所有变量处理 POST 数据时,PHP 会自动填充 $_POST 数组。数组的组件表示与表单输入元素关联的数据。要查看 $_POST 数组的内容,只需使用 var_dump($_POST);,或者您可以通过指定相应的数组键来访问各个值 (例如, $name = $_PO...
    编程 发布于2024-11-06
  • 对足球分析感兴趣?
    对足球分析感兴趣?
    我最近开始了我的足球分析之旅,并创建了一个示例 Python 程序,该程序引用 https://understat.com/ 来抓取单场比赛的射门数据。 这标志着我数据操作之旅的开始。我很高兴能更深入地研究这个领域,并期待随着我的进步分享更多更新。 回购: https://github.com/Ur...
    编程 发布于2024-11-06
  • 升级你的 JS:对象文字增强将改变你的代码
    升级你的 JS:对象文字增强将改变你的代码
    对象字面量是 JavaScript 的基本组成部分,使我们能够快速创建和初始化对象。在 ES6 及更高版本中,JavaScript 引入了对对象字面量的多项增强,使它们更加强大和简洁。让我们深入研究这些改进,看看它们如何使我们的代码更干净、更高效。 1. 属性简写名称 创建对象时,如...
    编程 发布于2024-11-06
  • 为什么我不能创建 `operator
    为什么我不能创建 `operator
    实现虚拟运算符
    编程 发布于2024-11-06
  • JavaScript 最佳实践。
    JavaScript 最佳实践。
    遵循 JavaScript 最佳实践有助于加快页面加载速度并提高性能,并提高代码可读性以及易于维护和调试。精心编写的代码还可以帮助避免错误和安全问题。 01。避免全局变量 尽量减少全局变量的使用。 这包括所有数据类型、对象和函数。 全局变量和函数可以被其他脚本覆盖。 改用局部变量并学习如何使用闭包...
    编程 发布于2024-11-06

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3