<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<script type="text/javascript">
window.onload = function (){
var oStar = document.getElementById("start");
var oSpan = oStar.getElementsByTagName("span")[0]; var oContent = document.getElementById("content");
var oRect = document.getElementById("rect");
var timer = null;
var oTime = document.getElementById("time"); var aImg = document.getElementsByTagName("img"); var arrImg = ["http://img3.douban.com/view/photo/thumb/public/p1994200192.jpg",
"http://img5.douban.com/view/photo/thumb/public/p1994200528.jpg",
"http://img3.douban.com/view/photo/thumb/public/p1994200963.jpg",
"http://img3.douban.com/view/photo/thumb/public/p1994201400.jpg",
"http://img3.douban.com/view/photo/thumb/public/p1994201804.jpg",
"http://img5.douban.com/view/photo/thumb/public/p1994201968.jpg",
"http://img3.douban.com/view/photo/thumb/public/p1994202154.jpg",
"http://img5.douban.com/view/photo/thumb/public/p1994202276.jpg",
"http://img3.douban.com/view/photo/thumb/public/p1994202342.jpg"]; var oScore = document.getElementById("score");
var oFail = document.getElementById("fail");
var oSuccess = document.getElementById("success");
var level = [{"num":"3","timeGame":"10"},
{"num":"4","timeGame":"10"},
{"num":"6","timeGame":"15"},
{"num":"8","timeGame":"20"}]; oSpan.onclick = function (){ var rating = 0;
starGame( level[rating].num,level[rating].timeGame,rating ); } // 游戏程序 参数分别代表 块数 游戏时间 等级
function starGame( num,timeGame,rating){ oStar.style.display = "none";
oFail.style.display = "none";
oSuccess.style.display = "none";
oContent.style.display = "block";
oContent.setAttribute("off","0"); oTime.style.width = "440px";
oScore.innerHTML = 0;
oRect.innerHTML = ""; fillContent(num);
setTimeout(function (){
for(var i = 0; i < aImg.length; i++){
aImg[i].src = "http://img3.douban.com/view/photo/thumb/public/p2191686093.jpg";
}
getTime( oTime,"width", -Math.floor( parseInt( getStyle(oTime,"width") )/timeGame ), timeGame, num*20, rating );
},3000);
} //填充块
function fillContent(size){
var arr = Mix(size,1,2);
//console.log(arr); for(var i = 0; i < arr.length; i++){
oRect.innerHTML += "<img style = 'top:"+ 110*Math.floor(i/4) +"px; left:"+ 110*Math.floor(i%4) +"px' select = 'N' index = " + i + " address = " + arrImg[arr[i]] +" src = "+ arrImg[arr[i]] +" num = "+ arr[i] + ">";
}
} function Mix( max,min,fre){
var arr = [];
for(var i = min; i <= max; i++ ){
arr.push(i);
}
var newarr = [getRandom(arr.length,1)];
for(var i = 0; newarr.length < arr.length*fre; i++ ){ var num = getRandom(arr.length,1); if( toCon(num,fre-1 ) ){
newarr.push(num);
}
} function toCon( num,fre ){
var iNow = 0;
for(var i = 0; i < newarr.length; i++ ){
if( num == newarr[i] && iNow != fre ){
++iNow;
}else if( num == newarr[i] && iNow == fre ){
return false;
}
}
return true;
} return newarr;
} function getTime( obj,attr,speed,time,totle,rating ){
clearInterval(obj.timer); selectRect(totle,rating);
obj.timer = setInterval( function (){ time--;
if( time != 0 ){
obj.style[attr] = parseInt( getStyle(obj,attr) ) + speed + "px";
if( parseInt(oContent.getAttribute("off")) == 1 ){
clearInterval(obj.timer);
}
} if( time == 0 ){
obj.style[attr] = "0px";
clearInterval(obj.timer);
for(var i = 0; i < aImg.length; i++ ){
aImg[i].src = aImg[i].getAttribute("address");
} //console.log( oContent.getAttribute("off") );
if( parseInt(oContent.getAttribute("off"))!= 1 ){ oContent.style.display = "none";
oFail.style.display = "block"; var oP = oFail.getElementsByTagName("p")[0]; oP.onclick = function (){ oFail.style.display = "none";
oStar.style.display = "block"; oSpan.onclick = function (){
starGame(level[0].num,level[0].timeGame,0);
}
}
} }
},1000)
} function selectRect(totle,rating){
var selectNum = 0;
var selectVal = [];
var selectIndex = [];
for(var i = 0; i < aImg.length; i++ ){
aImg[i].style.cursor = "pointer";
aImg[i].onclick = function(){
selectNum++;
this.style.border = "1px red solid";
this.src = this.getAttribute("address");
this.setAttribute("select","Y");
selectVal.push( parseInt( this.getAttribute("num")) );
selectIndex.push( parseInt( this.getAttribute("index")) ); //console.log(selectVal );
if( selectNum == 2 ){
selectNum = 0; if( selectVal.length == 2 ){
if( selectVal[0] == selectVal[1] && selectIndex[0]!= selectIndex[1] ){ toSelectSuccess(totle,rating);
oScore.innerHTML = parseInt( oScore.innerHTML ) + 20;
} else {
toSelectError();
}
}
selectVal = [];
selectIndex = [];
}
}
} function toSelectError(){
setTimeout (function(){
var selArrE = []; for(var i = 0; i < aImg.length; i++ ){
if( aImg[i].getAttribute("select") == "Y"){
selArrE.push( parseInt(aImg[i].getAttribute("index")) );
}
} for(var i = 0; i < aImg.length; i++ ){
for(var j = 0; j < selArrE.length; j++ ){
if( aImg[i].getAttribute("index") == selArrE[j] ){
aImg[i].src = aImg[i].getAttribute("address");
aImg[i].src = "http://img3.douban.com/view/photo/thumb/public/p2191686093.jpg";
aImg[i].style.border = "1px white solid";
aImg[i].setAttribute("select","N");
}
}
}
selArrE.length = 0;
},300);
} function toSelectSuccess( totle,rating){
setTimeout (function(){
var selArrS = [];
for(var i = 0; i < aImg.length; i++ ){
if( aImg[i].getAttribute("select") == "Y"){
selArrS.push( aImg[i].getAttribute("index") );
}
} //console.log(totle); for(var i = 0; i < aImg.length; i++ ){
for(var j = 0; j < selArrS.length; j++ ){
if( aImg[i].getAttribute("index") == selArrS[j] ){
aImg[i].src = aImg[i].getAttribute("address");
aImg[i].style.display = "none";
aImg[i].setAttribute("select","N");
}
}
}
selArrS.length = 0; if( parseInt( oScore.innerHTML ) == parseInt( totle ) ){ oContent.setAttribute("off","1");
oContent.style.display = "none";
oSuccess.style.display = "block"; var oP = oSuccess.getElementsByTagName("p")[0];
oP.onclick = function(){
rating++; if( rating == 4 ){
oStar.style.display = "block";
oFail.style.display = "none";
oSuccess.style.display = "none";
oContent.style.display = "none";
rating = 0; oSpan.onclick = function (){ starGame( level[0].num,level[0].timeGame,0 ); } } starGame( level[rating].num,level[rating].timeGame,rating); } } //console.log( selArr[0],selArr[1] );
var selArr = [];
//console.log( selArr[0],selArr[1] );
//var selArr = [];
},200);
} } function getStyle(obj,attr){
if(obj.currentStyle){
return obj.currentStyle[attr];
} else{
return getComputedStyle(obj)[attr];
}
} function getRandom( max, min){
return Math.floor( Math.random()*( max - min + 1) + min );
}
}
</script>
<style>
*{
padding: 0px;
margin: 0px;
}
#start{
background: url(images/background.jpg) no-repeat;
margin: 50px auto;
position: relative;
width: 800px;
height: 500px;
overflow: hidden;
display: block;
} #start span{
background: pink;
color: white;
position: absolute;
top: 400px;
left: 700px;
cursor: pointer;
padding: 15px;
} #content{
background: #cccccc;
margin: 50px auto;
position: relative;
width: 440px;
height: 440px;
display: none;
}
#content p{
position: absolute;
right: 5px;
top: -20px;
} #content #rect{
width: 440px;
height: 440px;
position: relative;;
} #content img{
border: 1px white solid;
width: 98px;
height: 98px;
margin: 5px;
position: absolute;
} #time{
width: 440px;
background: red;
height: 30px;
position: absolute;
bottom: -30px;
} #fail{
background: black;
margin: 50px auto;
width: 440px;
height: 440px;
display: none;
} #fail p {
margin: 50px auto;
font-size: 120px;
color:white;
cursor: pointer;
} #success{
background: red;
margin: 50px auto;
width: 440px;
height: 440px;
display: none;
} #success p {
margin: 50px auto;
font-size: 120px;
color:white;
cursor: pointer;
}
</style>
</head>
<body>
<div id = "start">
<span>start</span>
</div> <div id = "content" off = "0">
<p>Score: <span id = "score">0</span>point</p>
<div id = "time"></div>
<div id="rect"></div> </div> <div id = "fail">
<p>Failure!</p>
</div> <div id = "success">
<p>Success</p>
</div>
</body>
</html>

js 考记忆力得小游戏的更多相关文章

  1. 原生JS实现的h5小游戏-植物大战僵尸

    代码地址如下:http://www.demodashi.com/demo/12755.html 项目介绍 本项目是利用原生js实现的h5小游戏-植物大战僵尸,主要结合了一下自己对于h5小游戏的理解,结 ...

  2. js实现表格配对小游戏

    js实现表格配对小游戏 一.总结 一句话总结: 二.js实现表格配对 1.配对游戏案例说明 实例描述: 当用户点击两个相同的图案或字符后配对成功,全部配对成功后游戏获胜 案例008采用了大家常见的小游 ...

  3. JS实现植物大战僵尸小游戏,代码记录及效果展示

    前几天看到了一个很有趣的demo,用js制作植物大战僵尸小游戏,本着学习的心态,对照着做了一下,发现这里面的一些代码设计的确很精妙,这里分享下源码和效果,如果有需要,可以看下. 效果如下: 下载地址

  4. 原生js写的flybird小游戏

    游戏地址:http://zangzhihong.jusukeji.com/flybird/index.html html部分 <!DOCTYPE html>   <!-- This ...

  5. css3+jquery+js做的翻翻乐小游戏

    主要是为了练习一下css3的3D翻转功能,就做了这么个小游戏,做的比较粗糙,但是效果看的见. 主要用到的css3代码如下: html结构: <div class="container& ...

  6. 从零到一:用Phaser.js写意地开发小游戏(Chapter 3 - 加载游戏资源)

    回顾 上一节我们搭建了游戏的骨架,添加了四个游戏场景,分别是加载.开始.游戏.结束.那么这一节我们来介绍加载这个场景,顺带丰富一下各个场景的基本内容. Phaser.Loader Phaser框架自带 ...

  7. 原生JS制作贪吃蛇小游戏

    感情都在代码里,来,干了!... <!doctype html> <html> <head> <meta http-equiv="Content-T ...

  8. js实现点气球小游戏

    二话不说直接贴代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...

  9. js 面向对象 打气球小游戏

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

随机推荐

  1. Map 的两种遍历方法详细说明

    //方法一 Set<String> set = map.keySet(); for (String s:set) { System.out.println(s+","+ ...

  2. java BigDecimal工具类

    package com.core.calculate; import java.math.BigDecimal; import java.text.DecimalFormat; /** * Creat ...

  3. 【bzoj4836】[Lydsy2017年4月月赛]二元运算 分治+FFT

    题目描述 定义二元运算 opt 满足   现在给定一个长为 n 的数列 a 和一个长为 m 的数列 b ,接下来有 q 次询问.每次询问给定一个数字 c  你需要求出有多少对 (i, j) 使得 a_ ...

  4. [CQOI2015][bzoj3930] 选数 [杜教筛+莫比乌斯反演]

    题面: 传送门 思路: 首先我们把区间缩小到$\left[\lfloor\frac{L-1}{K}\rfloor,\lfloor\frac{R}{K}\rfloor\right]$ 这道题的最特殊的点 ...

  5. Vue.js笔记 — vue-router路由懒加载

    用vue.js写单页面应用时,会出现打包后的JavaScript包非常大,影响页面加载,我们可以利用路由的懒加载去优化这个问题,当我们用到某个路由后,才去加载对应的组件,这样就会更加高效,实现代码如下 ...

  6. ubuntu 配置虚拟主机

    ubuntu下Apache虚拟主机的配置   启用站点停用站点方法   a2ensite/a2dissite 比如添加一个ecshop 的虚拟机 首先到/etc/apache2/site-availa ...

  7. C/C++初学攻略

    最近有朋友问我C++(or C)怎么入门,其实这个还真不是很好回答的,想了下就写下这篇博文以说下我自己的学习路程吧! 正儿八经的,其实我觉得自己也学得不咋地,不管是C还是C++都是如此的强大,要真正的 ...

  8. Markdown语法格式

    Markdown是一种可以普通文本编辑器编写的标记语言,通过简单的标记语法,就可以使普通文本内容具有一定的格式.(摘自百度百科) 今天记录一下Markdown语法,以供以后使用时查询. 1.标题 用 ...

  9. python:virtualenv的使用

    安装virtualenv 使用pip安装:pip install virtualenv virtualenvwrapper 其中virtualenvwrapper是virtualenv的扩展工具,用于 ...

  10. C#图解教程学习笔记——接口

    一.接口概念接口是指定一组函数成员而不实现它们的引用类型.所以只能类和结构来实现接口. 二.声明接口1. 接口声明不能包含:数据成员.静态成员,只能包含以下类型的非静态成员函数:方法.属性.事件.索引 ...