怎样使用vue实现2048小游戏

这次给大家带来怎样使用vue实现2048小游戏,使用vue实现2048小游戏的注意事项有哪些,下面就是实战案例,一起来看一下。

使用方法:

git clonenpm inpm run dev

登录后复制

实现思路如下:

用vue-cli搭建项目,对这个项目可能有点笨重,但是也懒的再搭一个

4X4的方格用一个二维数组存放,绑定好后只关心这个二维数组,其他事交给vue

监听键盘事件

2048的核心部分就是移动合并的算法,因为是一个4X4的矩阵,所以只要实现左移的算法,其他方向的移动只需要将矩阵旋转,移动合并,再旋转回来,渲染dom即可

绑定不同数值的样式

分值计算,以及用localstorage存放最高分

关键实现

DOM

{col}}

登录后复制

主要的游戏部分的DOM,很简单,用一个二维数组渲染,并动态绑定样式

左移

主要由以下几种情况:

2 2 2 2 => 4 4 0 0

4 2 2 2 => 4 4 2 0

0 4 2 2=> 4 4 0 0

2 2 4 2 => 4 4 2 0

按单行数据举例,

遍历单行数组,若存在数据,记为cell,寻找cell往左可移到的最远空位置farthest

判断farthest的左边是否存在,不存在则直接移到到farthest

若存在,则判断farthest – 1的值和cell是否相同

相同=> 合并

不相同=>移到farthest位置

移动完后,清空cell

下一轮

因为一轮移动中,一个数只能合并一次,所以每个格子要有merged参数来记录是否已经合并过。

主要代码:

_list.forEach(item => {    let farthest = this.farthestPosition(list, item)    let next = list[farthest - 1]    if (next && next === item.value && !_list[farthest - 1].merged) {      //合并      list[farthest - 1] = next * 2      list[item.x] = undefined      item = {        x: farthest - 1,        merged: true,        value: next * 2      }      this.score += next * 2    } else {      if (farthest != item.x) {        list[farthest] = item.value        list[item.x] = undefined        item.x = farthest      }    }  })

登录后复制

矩阵旋转

因为上移,下移,左移,右移实际上是相同的,写4遍也可以,但是容易出错,所以我直接旋转将矩阵旋转,再进行移动。

以上移为例,只要将矩阵逆时针旋转一次,上移就变成了左移,移动合并成之后,只要再将矩阵逆时针旋转4-1次,矩阵就和单纯上移一样了。

逆时针旋转算法:

rotate(arr, n) {    n = n % 4    if (n === 0) return arr    let tmp = Array.from(Array(this.size)).map(() => Array(this.size).fill(undefined))    for (let i = 0; i < this.size; i++) {      for (let j = 0; j  1) tmp = this.rotate(tmp, n - 1)    return tmp  },

登录后复制

到这时候已经完成了80%了,只要再完善一下,加入分值,重新开始等功能就可以了。

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

如何操作Vue内使用vee-validate

node跨域使用express+http-proxy-middleware步骤详解

以上就是怎样使用vue实现2048小游戏的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2752347.html

(0)
上一篇 2025年3月8日 06:22:35
下一篇 2025年2月24日 05:32:23

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 怎样操作node实现爬虫效果

    这次给大家带来怎样操作node实现爬虫效果,操作node实现爬虫效果的注意事项有哪些,下面就是实战案例,一起来看一下。 node是服务器端的语言,所以可以像python一样对网站进行爬取,下面就使用node对博客园进行爬取,得到其中所有的章…

    2025年3月8日
    200
  • 怎样使用源生JS代码实现百度搜索框

    这次给大家带来怎样使用源生JS代码实现百度搜索框,使用源生JS代码实现百度搜索框的注意事项有哪些,下面就是实战案例,一起来看一下。 最近做了个百度搜索框今天给大家分享下。 效果:   1.当进入界面时,自动调用方法,获取当前的时间,并且实时…

    2025年3月8日
    200
  • 如何使用JS模拟实现哈希表

    这次给大家带来如何使用JS模拟实现哈希表,使用JS模拟实现哈希表的注意事项有哪些,下面就是实战案例,一起来看一下。 在算法中,尤其是有关数组的算法中,哈希表的使用可以很好的解决问题,所以这篇文章会记录一些有关js实现哈希表并给出解决实际问题…

    2025年3月8日
    200
  • 怎样使用Vue在页面右上角实现可悬浮/隐藏菜单

    这次给大家带来怎样使用Vue在页面右上角实现可悬浮/隐藏菜单,使用Vue在页面右上角实现可悬浮/隐藏菜单的注意事项有哪些,下面就是实战案例,一起来看一下。 这是个大多数网站很常见的功能,点击页面右上角头像显示一个悬浮菜单,点击页面其他位置或…

    2025年3月8日
    200
  • 怎样使用Vue+canvas实现移动端手写板功能

    这次给大家带来怎样使用Vue+canvas实现移动端手写板功能,使用Vue+canvas实现移动端手写板功能的注意事项有哪些,下面就是实战案例,一起来看一下。 清除 保存 Canvas画板 var draw;var preHandler =…

    编程技术 2025年3月8日
    200
  • 怎样使用react router4+redux实现路由权限控制

    这次给大家带来怎样使用react router4+redux实现路由权限控制,使用react router4+redux实现路由权限控制的注意事项有哪些,下面就是实战案例,一起来看一下。 总体概述 一个完善的路由系统应该是这样子的,当链接到…

    编程技术 2025年3月8日
    200
  • 怎样使用jquery实现左右上下移动功能

    这次给大家带来怎样使用jquery实现左右上下移动功能,使用jquery实现左右上下移动功能的注意事项有哪些,下面就是实战案例,一起来看一下。 最近再做报表时候,直接把全部字段都导出了,但这不太灵活。回忆老师讲过的项目做报表如下左右上下移功…

    2025年3月8日
    200
  • 怎样实现vue模态对话框

    这次给大家带来怎样实现vue模态对话框,实现vue模态对话框的注意事项有哪些,下面就是实战案例,一起来看一下。 写在前面 对话框是很常用的组件 , 在很多地方都会用到,一般我们可以使用自带的alert来弹出对话框,但是假如是设计出的图该怎么…

    2025年3月8日
    200
  • 怎样实现Vue项目中使用Vux

    这次给大家带来怎样实现Vue项目中使用Vux,Vue项目中使用Vux的注意事项有哪些,下面就是实战案例,一起来看一下。 默认已安装vue环境 1.安装vux npm install vux –save-dev 2.安装vux-l…

    2025年3月8日
    200
  • 使用缓存调用链实现JS方法重载步骤详解

    这次给大家带来使用缓存调用链实现JS方法重载步骤详解,使用缓存调用链实现JS方法重载的注意事项有哪些,下面就是实战案例,一起来看一下。 1.什么是方法重载 方法重载是指在一个类中定义多个同名的方法,但要求每个方法具有不同的参数的类型或参数的…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论