js实现翻牌小游戏


Posted in Javascript onJuly 31, 2020

本文实例为大家分享了js实现翻牌小游戏的具体代码,供大家参考,具体内容如下

效果图

js实现翻牌小游戏

需求分析

1、生成两组顺序随机的1-8数据
2、卡片需要有翻转效果
3、两次翻转数据不相等,回复原状
4、两次翻转数据相等,卡片相等,不能再被点击
5、当所有卡片不能被点击游戏结束
6、限制最大点击次数50次

HTML结构

<div class="wrap">
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
 <div>
  <p class="top"></p>
  <p class="bottom"></p>
 </div>
</div>

css布局

实现卡片翻转效果需要3个关键属性

1.perspective: 1000px; 透视深度,形成3d视角
2.transform: rotateY(180deg);旋转
3.backface-visibility: hidden; 元素背面不可见

* {
  margin: 0;
  padding: 0;
 }

 body,
 html {
  height: 100%;
 }

 .wrap {
  perspective: 1000px;
  width: 320px;
  height: 320px;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  display: flex;
  justify-content: center;
  text-align: center;
  flex-wrap: wrap;
 }

 .wrap div {
  /* box-shadow: 5px 5px 10px #000; */
  transition: 1s;
  position: relative;
  text-align: center;
  line-height: 60px;
  height: 60px;
  width: 60px;
  border-radius: 10px;

  margin: 10px 10px;
 }

 .wrap div .active1 {
  transform: rotateY(180deg);
 }

 .wrap div .active2 {
  transform: rotateY(360deg);
 }

 .wrap p {
  border-radius: 10px;
  background-color: blueviolet;
  transition: 1s;
  backface-visibility: hidden;
  display: block;
  height: 60px;
  width: 60px;
  position: absolute;
  /* transform: rotateY(180deg); */
 }

 .wrap .bottom {
  transform: rotateY(180deg);
 }
 h3{
  text-align: center;
  width: 200px;
  height: 30px;
  margin: 150px auto;
 }

js

class Game {
  constructor(selector) {
  this.init(selector);
  }
  init(selector) {
  let arr = this.randomArr();
  this.nodes = [...document.querySelectorAll(selector)];//获取每一个卡片
  this.step = 50;//定义可以被点击的次数
  this.tit = document.querySelector("h3");
  this.nodes.forEach((item,index) => {//初始化卡片的值,并保存在num属性中
   item.children[1].innerHTML = arr[index];
   item.num = arr[index];
   var that = this
   item.onclick = function () {//给每一个卡片绑定事件
   that.handle(this);
   }
  })
  }
  handle(ele) {
  if(this.step === 0){
   alert('游戏结束')
   return
  }
  if(ele.active !== true){
   this.step--;
   this.tit.innerText = `剩余步数:${this.step}`
  }
  ele.children[0].classList.add('active1');//卡片翻转
  ele.children[1].classList.add('active2'); 
  let res = this.nodes.filter(item => item.children[0].classList.contains('active1')&& item.active !== true); //获取翻过来的且没有配对成功的卡片
  if(res.length === 2 && res[0].num !== res[1].num){//如果有两张并且数值不相等,恢复原状 
   setTimeout(()=>{
   res[0].children[0].classList.remove('active1');
   res[0].children[1].classList.remove('active2');
   res[1].children[0].classList.remove('active1');
   res[1].children[1].classList.remove('active2'); 
   },1000)//延迟一秒形成动画 
  }else if(res.length === 2 && res[0].num === res[1].num){//如果数值相等则配对成功
   res[0].active = true;//锁定卡片
   res[1].active = true;
  }
  }
  randomArr() {
  let arr = [];
  for (let i = 0, n = 8; i < n; i++) {
   do {
   var item = randomInt(1, 8);
   } while (arr.indexOf(item) !== -1)
   arr.push(item);
  }
  arr.push(...arr);
  return arr;
  }
 }
 new Game('.wrap div')
 function randomInt(min, max) {//产生[min,max]范围内的整数
 return Math.round(Math.random() * (max - min)) + min
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
xmlHTTP实例
Oct 24 Javascript
JS继承--原型链继承和类式继承
Apr 08 Javascript
基于jQuery中对数组进行操作的方法
Apr 16 Javascript
javascript 获取iframe里页面中元素值的方法
Feb 17 Javascript
jQuery中append()方法用法实例
Jan 08 Javascript
深入理解js中this的用法
May 28 Javascript
微信小程序 wx:key详细介绍
Oct 28 Javascript
JavaScript之事件委托实例(附原生js和jQuery代码)
Jul 22 jQuery
Element input树型下拉框的实现代码
Dec 21 Javascript
微信小程序实现复选框效果
Dec 28 Javascript
Electron vue的使用教程图文详解
Jul 05 Javascript
如何使用50行javaScript代码实现简单版的call,apply,bind
Aug 14 Javascript
Vue 请求传公共参数的操作
Jul 31 #Javascript
vue2.0 解决抽取公用js的问题
Jul 31 #Javascript
vue实现公共方法抽离
Jul 31 #Javascript
js实现无缝轮播图插件封装
Jul 31 #Javascript
原生js滑动轮播封装
Jul 31 #Javascript
Vue+ElementUI 中级联选择器Bug问题的解决
Jul 31 #Javascript
jquery轮播图插件使用方法详解
Jul 31 #jQuery
You might like
php生成rss类用法实例
2015/04/14 PHP
jQuery 标题的自动翻转实现代码
2009/10/14 Javascript
javascript检测页面是否缩放的小例子
2013/05/16 Javascript
jQuery实现表头固定效果的实例代码
2013/05/24 Javascript
jQuery学习笔记之toArray()
2014/06/09 Javascript
jQuery统计上传文件大小的方法
2015/01/24 Javascript
JavaScript中的函数模式详解
2015/02/11 Javascript
详解JavaScript中void语句的使用
2015/06/04 Javascript
JavaScript图像延迟加载库Echo.js
2016/04/05 Javascript
jQuery实现ajax的叠加和停止(终止ajax请求)
2016/08/08 Javascript
微信小程序 wxapp视图容器 view详解
2016/10/31 Javascript
vue实现ToDoList简单实例
2017/02/07 Javascript
node+koa2+mysql+bootstrap搭建一个前端论坛
2018/05/06 Javascript
vue cli使用融云实现聊天功能的实例代码
2019/04/19 Javascript
详解node登录接口之密码错误限制次数(含代码)
2019/10/25 Javascript
JSON获取属性值方法代码实例
2020/06/30 Javascript
[54:51]Ti4 冒泡赛第二轮LGD vs C9 3
2014/07/14 DOTA
[44:50]2018DOTA2亚洲邀请赛 4.1 小组赛 A组 TNC vs VG
2018/04/02 DOTA
Python之pandas读写文件乱码的解决方法
2018/04/20 Python
Django项目中用JS实现加载子页面并传值的方法
2018/05/28 Python
python 3.3 下载固定链接文件并保存的方法
2018/12/18 Python
pycharm中使用anaconda部署python环境的方法步骤
2018/12/19 Python
详解python校验SQL脚本命名规则
2019/03/22 Python
Django集成搜索引擎Elasticserach的方法示例
2019/06/04 Python
django项目环境搭建及在虚拟机本地创建django项目的教程
2019/08/02 Python
Python+AutoIt实现界面工具开发过程详解
2019/08/07 Python
python读写csv文件的方法
2019/08/13 Python
Python列表list操作相关知识小结
2020/01/29 Python
找到不普通的东西:Bonanza
2016/10/20 全球购物
在线实验室测试:HealthLabs.com
2020/05/03 全球购物
暑期实践思想汇报
2014/01/06 职场文书
21岁生日感言
2014/02/27 职场文书
2016年校园植树节广播稿
2015/12/17 职场文书
PHP命令行与定时任务
2021/04/01 PHP
Javascript webpack动态import
2022/04/19 Javascript
CSS浮动引起的高度塌陷问题
2022/08/05 HTML / CSS