HTML骨架:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>别踩白块</title>
<link rel="stylesheet" href="index.css">
</head>
<body>
<div class="box">
<h2 id="score">0</h2>
<div class="main">
<div class="content"></div>
</div>
<button id="startBtn">开始游戏</button>
</div>
<script src="index.js"></script>
</body>
</html>
CSS代码:
* {
margin: 0;
padding: 0;
}
/* 包裹所有内容的大盒子 */
.box {
margin-top: 60px;
}
/* 展示分数 */
h2 {
text-align: center;
}
/* 游戏界面 */
.main {
width: 408px;
height: 408px;
margin: 20px auto;
border: 2px solid gray;
overflow: hidden;
}
/* 内容盒子,存放黑白块 */
.content {
position: relative;
width: 100%;
height: 400px;
top: -408px;
border-collapse: collapse;
}
/* 一行黑白块 */
.row {
width: 100%;
height: 100px;
}
/* 白块 */
.column {
float: left;
width: 100px;
height: 100px;
border: 1px solid gray;
}
/* 黑块,给白块加上该类名就可以设置黑块 */
.black {
background-color: #000;
}
/* 开始游戏按钮 */
#startBtn {
display: block;
width: 100px;
height: 35px;
margin: 0 auto;
background-color: black;
color: #fff;
cursor: pointer;
outline: none;
border: none;
}
JS代码
var flag = false;
var clock = null;
var speed = 4;
var startBtn = document.querySelector('#startBtn');
var main = document.querySelector('.main');
var content = document.querySelector('.content');
function createWB() {
var classAry = ['column', 'column', 'column', 'column'];
var i = Math.floor(Math.random() * 4);
classAry[i] = 'column black';
return classAry;
}
function createDiv(classname) {
var div = document.createElement('div');
div.className = classname;
return div;
}
function creatRow() {
var row = createDiv('row');
content.appendChild(row);
var colAry = createWB();
for (var i = 0; i < 4; i++) {
var column = createDiv(colAry[i]);
row.appendChild(column);
}
if (content.firstChild == null) {
content.appendChild(row);
}
else {
content.insertBefore(row, content.firstChild);
}
}
function delRow() {
if (content.childNodes.length == 6) {
content.removeChild(content.lastChild);
}
}
function score() {
var score = document.querySelector('#score');
var newScore = parseInt(score.innerHTML) + 1;
score.innerHTML = newScore;
if (newScore % 10 == 0) {
speed += 2;
}
}
function judgeWB(ev) {
if (ev.target.className.indexOf('black') == -1 && ev.target.className.indexOf('column') !== -1) {
ev.target.parentNode.clickW = 1;
}
if (ev.target.className.indexOf('black') !== -1) {
ev.target.className = 'column';
ev.target.parentNode.clickB = 1;
score();
}
}
function move() {
var top = parseInt(window.getComputedStyle(content, null)['top']);
if (top + speed > 0) {
top = 0;
} else {
top += speed;
}
content.style.top = top + 'px';
judgeOver();
if (top == 0) {
creatRow();
content.style.top = '-102px';
delRow();
}
}
function init() {
flag = true;
for (var i = 0; i < 4; i++) {
creatRow();
}
main.onclick = function(ev) {
judgeWB(ev);
}
clock = window.setInterval('move()', 30);
}
startBtn.onclick = function() {
if (!flag) {
init();
}
else {
alert('不要重复点击');
}
}
function over() {
clearInterval(clock);
flag = false;
var score = document.querySelector('#score');
confirm('最终得分:' + parseInt(score.innerHTML) + '分')
score.innerHTML = 0;
content.innerHTML = '';
content.style.top = '-408px';
}
function judgeOver() {
var rows = content.childNodes;
if (rows.length == 5 && rows[rows.length - 1].clickB !== 1) {
over();
}
for (var i = 0; i < rows.length; i++) {
if (rows[i].clickW == 1) {
over();
}
}
}