vue实现2048小游戏功能思路详解


Posted in Javascript onMay 09, 2018

试玩地址

项目地址

使用方法:

git clone
npm i
npm run dev

实现思路如下:

  1. 用vue-cli搭建项目,对这个项目可能有点笨重,但是也懒的再搭一个
  2. 4X4的方格用一个二维数组存放,绑定好后只关心这个二维数组,其他事交给vue
  3. 监听键盘事件
  4. 2048的核心部分就是移动合并的算法,因为是一个4X4的矩阵,所以只要实现左移的算法,其他方向的移动只需要将矩阵旋转,移动合并,再旋转回来,渲染dom即可
  5. 绑定不同数值的样式
  6. 分值计算,以及用localstorage存放最高分

关键实现

DOM

<div class="box">
  <div class="row" v-for="row in list">
    <div class="col" :class="'n-'+col" v-for="col in row">{col}}</div>
  </div>
</div>

主要的游戏部分的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

按单行数据举例,

  1. 遍历单行数组,若存在数据,记为cell,寻找cell往左可移到的最远空位置farthest
  2. 判断farthest的左边是否存在,不存在则直接移到到farthest
  3. 若存在,则判断farthest - 1的值和cell是否相同
  4. 相同=> 合并
  5. 不相同=>移到farthest位置
  6. 移动完后,清空cell
  7. 下一轮

因为一轮移动中,一个数只能合并一次,所以每个格子要有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 < this.size; j++) {
        tmp[this.size - 1 - i][j] = arr[j][i]
      }
    }
    if (n > 1) tmp = this.rotate(tmp, n - 1)
    return tmp
  },

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

总结

以上所述是小编给大家介绍的vue实现2048小游戏功能思路详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
表单的一些基本用法与技巧
Jul 15 Javascript
深入认识JavaScript中的函数
Jan 22 Javascript
判断多个元素(RADIO,CHECKBOX等)是否被选择的原理说明
Feb 18 Javascript
javascript之学会吝啬 精简代码
Apr 25 Javascript
jQuery源码分析-02正则表达式 RegExp 常用正则表达式
Nov 14 Javascript
Webpack 实现 AngularJS 的延迟加载
Mar 02 Javascript
Bootstrap每天必学之轮播(Carousel)插件
Apr 25 Javascript
基于JSON格式数据的简单jQuery幻灯片插件(jquery-slider)
Aug 10 Javascript
正则中的回溯定义与用法分析【JS与java实现】
Dec 27 Javascript
详解Vue.js分发之作用域槽
Jun 13 Javascript
vue使用v-for实现hover点击效果
Sep 29 Javascript
JavaScript实现密码强度实时验证
Mar 18 Javascript
vue中父子组件注意事项,传值及slot应用技巧
May 09 #Javascript
vue中的provide/inject的学习使用
May 09 #Javascript
详解Vue 多级组件透传新方法provide/inject
May 09 #Javascript
自定义vue组件发布到npm的方法
May 09 #Javascript
React Navigation 使用中遇到的问题小结
May 08 #Javascript
官方推荐react-navigation的具体使用详解
May 08 #Javascript
JavaScript callback回调函数用法实例分析
May 08 #Javascript
You might like
PHP开发中常用的三个表单验证函数使用小结
2010/03/03 PHP
详解WordPress开发中的get_post与get_posts函数使用
2016/01/04 PHP
PHP+iframe图片上传实现即时刷新效果
2016/11/18 PHP
用PHP去掉文件头的Unicode签名(BOM)方法
2017/06/22 PHP
laravel 实现设置时区的简单方法
2019/10/10 PHP
msn上的tab功能Firefox对childNodes处理的一个BUG
2008/01/21 Javascript
类似CSDN图片切换效果脚本
2009/09/17 Javascript
Javascript 判断客户端浏览器类型代码
2010/03/01 Javascript
js获得指定控件输入光标的坐标兼容IE,Chrome,火狐等多种主流浏览器
2013/05/21 Javascript
javascript中call apply 的应用场景
2015/04/16 Javascript
纯javascript响应式树形菜单效果
2015/11/10 Javascript
jQuery fancybox在ie浏览器下无法显示关闭按钮的解决办法
2016/02/19 Javascript
AngularJS开发教程之控制器之间的通信方法分析
2016/12/25 Javascript
jQuery实现标签页效果实战(4)
2017/02/08 Javascript
jQuery实现base64前台加密解密功能详解
2017/08/29 jQuery
用原生 JS 实现 innerHTML 功能实例详解
2019/04/03 Javascript
vue中使用elementUI组件手动上传图片功能
2019/12/13 Javascript
Python运行的17个时新手常见错误小结
2012/08/07 Python
python实现ipsec开权限实例
2014/11/11 Python
利用python实现命令行有道词典的方法示例
2017/01/31 Python
Python 正则表达式实现计算器功能
2017/04/29 Python
浅析使用Python操作文件
2017/07/31 Python
Python中字符串与编码示例代码
2019/05/20 Python
Python 一键获取百度网盘提取码的方法
2019/08/01 Python
使用python模拟命令行终端的示例
2019/08/13 Python
Python2比较当前图片跟图库哪个图片相似的方法示例
2019/09/28 Python
Tensorflow限制CPU个数实例
2020/02/06 Python
Python环境下安装PyGame和PyOpenGL的方法
2020/03/25 Python
国家地理在线商店:Shop National Geographic
2018/06/30 全球购物
会计电算化应届生求职信
2013/11/03 职场文书
毕业生自荐材料范文
2014/12/30 职场文书
年度考核个人总结
2015/03/06 职场文书
2015年城管个人工作总结范文
2015/04/20 职场文书
2016年寒假生活小结
2015/10/10 职场文书
2016年十一促销广告语
2016/01/28 职场文书
Python中json.dumps()函数的使用解析
2021/05/17 Python