别踩白块JS代码实现

2024-08-23 23:08
文章标签 代码 实现 js 白块

本文主要是介绍别踩白块JS代码实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

</pre><strong><span style="font-size:48px;">1.思路:</span><span style="font-size:24px; white-space: pre;">	</span><span style="font-size:24px;">1.创建DIV容器;例如:400*400</span><span style="font-size:24px; white-space: pre;">	</span><span style="font-size:24px;">2.创建4行DIV</span><span style="font-size:24px; white-space: pre;">	</span><span style="font-size:24px;">3.4行DIV中,再放4列DIV,float left</span><span style="font-size:24px; white-space: pre;">	</span><span style="font-size:24px;">4.写一个方法,创建4列子DIV,创建一行DIV,把一行四列,插入到容器中</span><span style="font-size:24px; white-space: pre;">	</span><span style="font-size:24px;">5.定时器,没30毫秒增加TOP值</span><span style="font-size:24px; white-space: pre;">	</span><span style="font-size:24px;">6.没往下滑100px时,再创建一行四列,插入在窗口的最前面。</span></strong><pre name="code" class="html">

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="zh-CN">
<head>
<title>别踩白块</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="description" content="http://blog.csdn.net/u012989536"/>
<style>#main {width: 400px;height: 400px;border: 2px solid green;margin: 0 auto;position: relative;overflow: hidden;}#container {width: 100%;height: 400px;position: relative;top:-100px;background: white;}.row {width: 100%;height: 100px;}.cell {width: 100px;height: 100px;float:left;}.black {background: black;}#score {text-align: center;}
</style>
</head><body><h1 id="score">0</h1><div id="main"><div id="container"></div></div></body><script>var clock = null; // 定时器操作句柄var state = 0; // 0初始化,1进行中, 2 暂停, 3失败var speed = 4;/** 初始化*/function init() {for(var i=0; i<4; i++) {crow();}$('main').onclick = function (ev) {judge(ev);}}function judge(ev) {if(state == 3) {alert('失败者禁入');return;}if(ev.target.className.indexOf('black') == -1) {} else {ev.target.className = 'cell';ev.target.parentNode.pass = 1;score();}//console.log(ev.target);}/** start() 启动*/function start(){clock = window.setInterval('move()' , 40);}/** 动画*/function move() {var con = $('container');var top = parseInt(window.getComputedStyle(con , null)['top']);if(speed + top > 0) { //一步会走过头,直接top=0top = 0;} else {top += speed; //调节每次下降的像素}con.style.top = top + 'px';// if(top == 0) {crow();con.style.top = '-100px';drow();} else if(top == (-100 + speed)) {//console.log(con.lastChild);var rows = con.childNodes;if( (rows.length == 5) && (rows[rows.length-1].pass !== 1)) {fail();} }}/** 加速函数*/function jiasu() {speed +=2;if(speed == 20) {alert('你的电脑太卡了');}}/** 输,结束*/function fail() {clearInterval(clock);state = 3;alert('结束');}/** 计分*/function score() {var newscore = parseInt($('score').innerHTML)+1;$('score').innerHTML = newscore;if(newscore % 10 == 0) {jiasu();}}/** 创建div.row*/function crow(){var con = $('container');var row = cdiv('row');var classes = createSn();for(var i=0; i<4; i++) {row.appendChild(cdiv(classes[i]));}if(con.firstChild == null) {con.appendChild(row);} else {con.insertBefore(row , con.firstChild);}}/** 删除最后一行*/function drow(){var con = $('container');if(con.childNodes.length == 6) {con.removeChild(con.lastChild);}}/*** 创建div,className是其类名*/function cdiv(className) {var div = document.createElement('div');div.className = className;return div;}/*** 返回1个数组,随机其中1个单元,值为'cell black',其他3个,皆为cell**/function createSn() {var arr = ['cell','cell','cell','cell'];var i = Math.floor(Math.random()*4);arr[i] = 'cell black';return arr; }/** 按id获取对象*/function $(id) {return document.getElementById(id);}init();start();</script>
</html>



效果展示


这篇关于别踩白块JS代码实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1100759

相关文章

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

PyQt6/PySide6中QTableView类的实现

《PyQt6/PySide6中QTableView类的实现》本文主要介绍了PyQt6/PySide6中QTableView类的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学... 目录1. 基本概念2. 创建 QTableView 实例3. QTableView 的常用属性和方法

PyQt6/PySide6中QTreeView类的实现

《PyQt6/PySide6中QTreeView类的实现》QTreeView是PyQt6或PySide6库中用于显示分层数据的控件,本文主要介绍了PyQt6/PySide6中QTreeView类的实现... 目录1. 基本概念2. 创建 QTreeView 实例3. QTreeView 的常用属性和方法属性

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

pandas中位数填充空值的实现示例

《pandas中位数填充空值的实现示例》中位数填充是一种简单而有效的方法,用于填充数据集中缺失的值,本文就来介绍一下pandas中位数填充空值的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是中位数填充?为什么选择中位数填充?示例数据结果分析完整代码总结在数据分析和机器学习过程中,处理缺失数

Golang HashMap实现原理解析

《GolangHashMap实现原理解析》HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持高效的插入、查找和删除操作,:本文主要介绍GolangH... 目录HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数

Java对象转换的实现方式汇总

《Java对象转换的实现方式汇总》:本文主要介绍Java对象转换的多种实现方式,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java对象转换的多种实现方式1. 手动映射(Manual Mapping)2. Builder模式3. 工具类辅助映

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服