原生javascript扫雷游戏
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>扫雷游戏</title>
<meta http-equiv="Content-Language" content="zh-CN" />
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="Generator" content="Notepad++" />
<meta name="Robots" content="all" />
<meta name="Author" content="622" />
<meta name="Keywords" content="模版" />
<meta name="Description" content="模版" />
<meta name="Copyright" content="Copyright (c) 2014 rick All Rights Reserved." />
<script language="javascript"></script>
<style>
.all{margin:0 auto; width:960px;}
ul,li{margin:0; padding:0; list-style:none;}
#block>ul{height:32px; cursor:pointer;}
#block>ul>li{float:left; width:30px; height:30px; border:1px solid black; background:gray; color:white; text-align:center; position:relative;}
#block>ul>li>span{position:absolute; top:0; left:0; height:30px; width:30px; background:#eee;}
#ctrl{margin:20px auto;}
</style>
</head>
<body>
<div class="all">
<h1>小乐扫雷大作战</h1>
<form id="ctrl">
<label>行(1~30)<input type="text" id="row_n" value="10" /></label><br />
<label>列(1~30)<input type="text" id="col_n" value="10" /></label><br />
<label>雷的比例(1~0.01)<input type="text" id="thunder_n" value="0.3" /></label><br />
<input type="button" id="submit" value="提交" />
<input type="reset" id="reset" value="重置" /><br />
<label>提示消息<input type="text" id="msg" readonly="ture" /></label>
</form>
<div id="block"></div>
</div>
</body>
</html>
document.oncontextmenu=function ()
{
return false; //阻止默认事件
};
window.onload=function(){
var oSubmit = document.getElementById("submit");
//var oReset = document.getElementById("reset");
//var oRow_n = document.getElementById("row_n");
//var oCol_n = document.getElementById("col_n");
//var oThunder_n = document.getElementById("thunder_n");
var oMsg = document.getElementById("msg");
oMsg.value = "请输入要挑战的雷阵!";
oSubmit.onclick = init;
function init(){
var oSubmit = document.getElementById("submit");
var oReset = document.getElementById("reset");
var oRow_n = document.getElementById("row_n");
var oCol_n = document.getElementById("col_n");
var oThunder_n = document.getElementById("thunder_n");
var oMsg = document.getElementById("msg");
//参数设置
var m = oRow_n.value; //行
var n = oCol_n.value; //列
var p = oThunder_n.value;
var x = Math.floor(m*n*p); //雷的数目
//console.log(m,n,x);
if(!(m<30&&m>=0&&n<30&&n>=0&&p>=0&&p<=1)){
oMsg.value = "参数不合法";
}else{
oMsg.value = "参数设置成功";
var oDiv = document.getElementById("block");
oDiv.innerHTML = "";
var array = new Array(m);
//布局
for(var j=0; j<m; j++){
var oUl = document.createElement("ul");
array[j] = new Array(n);
for(var i=0; i<n; i++){
var oLi = document.createElement("li");
oUl.appendChild(oLi);
array[j][i] = [0,0,0]; //[是否是雷,标记状态,周围雷数]
}
oDiv.appendChild(oUl);
}
//初始化雷区
for(var i=0; i<x; i++){
var a = Math.floor(Math.random() * m);
var b = Math.floor(Math.random() * n);
if(array[a][b][0] == 0){
array[a][b][0] = 1;
valid(a-1,b-1);
valid(a-1,b);
valid(a-1,b+1);
valid(a,b-1);
valid(a,b+1);
valid(a+1,b-1);
valid(a+1,b);
valid(a+1,b+1);
}else{
x++;
}
}
//布雷
for(var i=0; i<m; i++){
for(var j=0; j<n; j++){
oLi = getBlock(i,j);
if(array[i][j][0] == 0){
oLi.innerHTML = array[i][j][2];
}else{
oLi.innerHTML = "#";
oLi.style.background = "red";
}
var oSpan = document.createElement("span");
oLi.appendChild(oSpan);
}
}
//监听事件
for(var i=0; i<m; i++){
for(var j=0; j<n; j++){
var oSpan = getBlock(i,j).getElementsByTagName("span")[0];
oSpan._i = i;
oSpan._j = j;
function listen_1(){
if(array[this._i][this._j][1]==2) return false;
this.style.display = "none";
array[this._i][this._j][1] = 1;
check();
if(array[this._i][this._j][0]==1){
alert("game over");
oMsg.value = "抱歉,挑战失败";
var aSpan = oDiv.getElementsByTagName("span");
for(var m=0; m < aSpan.length; m++){
aSpan[m].style.display = "none";
}
}
}
function listen_2(){
if(array[this._i][this._j][1] == 0){
array[this._i][this._j][1] = 2;
this.style.backgroundColor = "red";
check();
}else{
array[this._i][this._j][1] = 0;
this.style.backgroundColor = "#eee";
check();
}
}
function check(){
console.log(array);
var f=1;
for(var i=0; i<m; i++){
for(var j=0; j<n; j++){
console.log(array[i][j]);
if(array[i][j][0]==0){
if(array[i][j][1]!=1){
f=0;
break;
break;
}
}
if(array[i][j][0]==1){
if(array[i][j][1]!=2){
f=0;
break;
break;
}
}
}
}
if(f==1){
alert("恭喜挑战成功");
oMsg.value = "恭喜挑战成功";
}
}
on(oSpan,"click",listen_1);
on(oSpan,"contextmenu",listen_2);
}
}
}
function valid(x,y){
if(x>=0&&x<m&&y>=0&&y<n){
array[x][y][2] ++;
}
}
}
function getBlock(m,n){
var oDiv = document.getElementById("block");
var aUl = oDiv.getElementsByTagName("ul");
var ali = aUl[m].getElementsByTagName("li");
var oLi = ali[n];
return oLi;
}
function on(node,eventType,handler){
node = typeof node == "string" ? document.getElementById(node) : node;
if(document.all){
node.attachEvent("on" + eventType, handler);
}else{
node.addEventListener(eventType, handler, false);
}
}
}
原生javascript扫雷游戏的更多相关文章
- 原生javascript开发仿微信打飞机小游戏
今天闲来无事,于是就打算教一个初学javascript的女童鞋写点东西,因此为了兼顾趣味性与简易程度,果断想到了微信的打飞机小游戏.. 本来想用html5做的,但是毕竟人家才初学,连jquery都还不 ...
- 用原生javascript模拟经典FC游戏公路争霸
#用原生javascript模拟经典FC游戏公路争霸 前几天看了园子里面的随笔 [原生javascript开发仿微信打飞机小游戏](http://www.cnblogs.com/Mr-Nobody/p ...
- Javascript 综合示例 网页扫雷游戏
---------------认定了的事情,只要是对的,干到底! ------------------------------------------------------------------- ...
- javascript+HTMl5游戏下载,开发一个都能月薪上万!舅服你
HTML5时代已经到来许久了,你是否已经掌握了那么一点呢?今天小编给大家讲讲h5的折叠多设备.跨平台特性, 即用HTML5制作游戏.相比flash,HTML5更加灵活方便,随着浏览器技术的不断升级,H ...
- 原生JavaScript运动功能系列(二):缓冲运动
匀速运动实现回顾 缓冲运动剖析 示例实现 方法提取 匀速运动实现回顾及缓冲运动剖析: 在这个系列的上一篇博客中原生JavaScript运动功能系列(一):运动功能剖析与匀速运动实现就运动的核心功能组成 ...
- C# -- HttpWebRequest 和 HttpWebResponse 的使用 C#编写扫雷游戏 使用IIS调试ASP.NET网站程序 WCF入门教程 ASP.Net Core开发(踩坑)指南 ASP.Net Core Razor+AdminLTE 小试牛刀 webservice创建、部署和调用 .net接收post请求并把数据转为字典格式
C# -- HttpWebRequest 和 HttpWebResponse 的使用 C# -- HttpWebRequest 和 HttpWebResponse 的使用 结合使用HttpWebReq ...
- 原生 Javascript 编写五子棋
原文地址:原生 Javascript 编写五子棋 博客地址:http://www.extlight.com 一.背景 近一个月没写 Javascript 代码,有点生疏.正好浏览网页时弹出五子棋的游戏 ...
- 20 个使用原生 JavaScript 实现的 Web 项目
20 个使用原生 JavaScript 实现的 Web 项目 20 vanilla JavaScript Web Projects https://github.com/learning-js-by- ...
- 原生javascript 实现 animate
原生javascript 实现 animate //animate function getstyle(obj,name){ if(obj.currentStyle){ return obj.curr ...
随机推荐
- SHELL 近期学习
由于项目中很少使用到shell脚本所以.只是偶尔自学一点.慢慢积累.下面就把近段时间积累的发出来.学习. #sort sort 按首字母排序 sort -n 按数字大小 从小到大排序 sort -rn ...
- iOS基础 - 数据库CoreData
一.iOS应用数据存取的常用方式 XML属性列表 —— PList NSKeyedArchiver 归档 Preference(偏好设置) SQLite3 Core Data 二.Core Data简 ...
- 关于Django模板引擎的研究
原创博文,转载请注明出处. 以前曾遇到过错误Reverse for ‘*’ with arguments '()' and keyword arguments' not found.1其原因是没有给视 ...
- JQuery的插件式开发
如果你只会JQuery的插件式开发, 那么你可以进来看看? 对于JQuery的学习,已经有3年多的时间了,直到去年与我的组长一起做项目,看到他写的JS,确实特别漂亮,有时甚至还看不太懂, 我才发现其实 ...
- AHOI1997彩旗飘飘 VIJOS1097合并果子(noip2007)
AHOI彩旗飘飘 这是一题类似于排列组合的题目吧...递推状态 数组f[100][100][100][2];表示红旗数目,黄旗数目,颜色改变的次数,末尾的旗的颜色(0为黄,1为红) 之后就是如何写递推 ...
- C# 线程的定义和使用
C# 线程的定义和使用 一.C# Thread类的基本用法 通过System.Threading.Thread类可以开始新的线程,并在线程堆栈中运行静态或实例方法.可以通过Thread类的的构造方法传 ...
- linux 安装svn,并设置钩子来同步更新
linux安装svn下载 http://subversion.tigris.org/downloads/subversion-1.6.6.tar.gz 和 http://subversion.tigr ...
- 在MVC中添加异常增加日志
MVC的结构非常棒,基本你能想到注入的地方都可以找到地方,譬如IActionFilter,IResultFilter,IAuthorizationFilter以及IExceptionFilter 以下 ...
- QSQL导出mapfile和mapfile中PostGIS连接的一点心得
昨天弄QSQL导出mapfile,一直遇到下图的错误 原因是QGIS在渲染图层时候使用了新的符号,在图层上右键-属性,如下图将符号修改就OK了 然后我尝试使用QGIS连接本机PostGIS数据,结果老 ...
- xls===>csv tables===via python ===> sqlite3.db
I've got some files which can help a little bit to figure out where people are from based on their I ...