欧美一区二区三区,国内熟女精品熟女A片视频小说,日本av网,小鲜肉男男GAY做受XXX网站

javascript九宮格拼圖

沈明麗1年前8瀏覽0評論

在前端網(wǎng)頁制作中,JavaScript被廣泛應用于動畫、數(shù)據(jù)交互等方面。今天我們來探討一下JavaScript實現(xiàn)的九宮格拼圖。

九宮格拼圖是一種非常受歡迎的游戲,許多人都喜歡玩。通常來說,九宮格拼圖是由一個3x3的方格組成的。每個方格可以表示一個數(shù)字或圖片,九個方格被打散,玩家的目標是把被打散的方格重新排列成正確的順序。

var array = [1, 2, 3, 4, 5, 6, 7, 8, 0];
var initArray = array.slice();
var isInit = true;
function init(){
randomArray(array);
while(!checkArray(array)){
randomArray(array);
}
showArray();
}

上述代碼定義了一個長度為9的數(shù)組,并將它們打亂,然后通過循環(huán)檢查數(shù)組是否有序,并在打亂成無序狀態(tài)下顯示數(shù)組。

function randomArray(a){
var len = a.length;
var b = [];
for(var i = 0;i < len;i ++){
b[i] = a[i];
}
for(var i = 0;i < len;i ++){
// 獲取隨機數(shù),并交換數(shù)組元素
var index = Math.floor(Math.random() * b.length);
a[i] = b[index];
b.splice(index, 1);
}
}

以上代碼的randomArray()函數(shù)是用來打亂數(shù)組順序的。首先將原始數(shù)組備份到b數(shù)組中,然后通過循環(huán)遍歷b數(shù)組,獲取隨機數(shù),將原數(shù)組的元素與隨機得到的元素進行交換,最后返回打亂的新數(shù)組。

function checkArray(a){
var len = a.length;
for(var i = 0;i < len;i ++){
if(a[i] != initArray[i]){
return false;
}
}
return true;
}

checkArray()函數(shù)用于檢查數(shù)組是否已排序。它對初始數(shù)組和當前數(shù)組進行逐個比對,若有任意不同,則返回false,即數(shù)組未排序;反之,則返回true,表示數(shù)組已經(jīng)排序好了。

至此,九宮格拼圖的核心邏輯已經(jīng)實現(xiàn)。我們還需要使用HTML和CSS將它們渲染到頁面上。

<div id="wrap">
<div class="box" id="div1" onclick="move(1)"></div>
<div class="box" id="div2" onclick="move(2)"></div>
<div class="box" id="div3" onclick="move(3)"></div>
<div class="box" id="div4" onclick="move(4)"></div>
<div class="box" id="div5" onclick="move(5)"></div>
<div class="box" id="div6" onclick="move(6)"></div>
<div class="box" id="div7" onclick="move(7)"></div>
<div class="box" id="div8" onclick="move(8)"></div>
<div class="box" id="div0" onclick="move(0)"></div>
</div>

上面的代碼定義了一個容器wrapper,并將其中的九個方塊都設置為box類,并指定了它們的ID。我們需要使用CSS來定義它們的樣式:

#wrap{
width: 298px;
height: 298px;
margin: 20px auto;
}
.box{
float: left;
width: 100px;
height: 100px;
background-image: url(imgs/1.jpg);
background-size: 300px 300px;
background-color: #FFF;
margin: 1px 1px 0 0;
cursor: pointer;
font-size: 3em;
line-height: 100px;
text-align: center;
color: #666;
font-weight: bold;
}
#div0{
visibility: hidden;
}

最后我們需要實現(xiàn)move()函數(shù),用于移動方塊。

var blankX = 0;
var blankY = 0;
function move(index){
var div = document.getElementById("div" + index);
var x = div.offsetLeft;
var y = div.offsetTop;
if(x == blankX && y == blankY + 100 || 
x == blankX && y == blankY - 100 || 
x == blankX + 100 && y == blankY || 
x == blankX - 100 && y == blankY)
{
div.style.left = blankX + "px";
div.style.top = blankY + "px";
blankX = x;
blankY = y;
}
}

move()函數(shù)定義了兩個變量坐標blankX和blankY,用于表示空白方塊的位置,它們的初始值都為0。當我們點擊一個方塊時,先獲取到該方塊的坐標,通過判斷該方塊是否符合移動條件,如果符合,則將該方塊移動到空白方塊所在的位置,并更新坐標blankX和blankY。

以上就是實現(xiàn)JavaScript九宮格拼圖的全部代碼了。我們可以在一個HTML文件中,使用<script>標簽將上面的代碼引用,即可得到一個完整的九宮格拼圖。