基于JS實(shí)現(xiàn)簡(jiǎn)單滑塊拼圖游戲
成品效果
<body> <div id="game" style="position:relative"></div> </body> /** * js配置 */ var config = { width: 300, height: 300, img: "./img/fj.jpg", gameDom: document.getElementById("game"), row: 3, //3行 col: 3 //3列 } //經(jīng)過(guò)計(jì)算的一些數(shù)據(jù) var computed = { num: config.col * config.row, //方塊數(shù)量 w: config.width / config.col, //每個(gè)小方塊的寬度 h: config.height / config.row //每個(gè)小方塊的高度 } //方塊對(duì)象的數(shù)組,每個(gè)對(duì)象中記錄了方塊的正確坐標(biāo)、當(dāng)前坐標(biāo)、dom元素、以及一些實(shí)用方法 var blocks; /** * 為全局變量blocks賦值 */ function setBlocks() { blocks = []; var points = getPointsArray(); //該數(shù)組用于設(shè)置每個(gè)方塊的正確坐標(biāo) var shuffledPoints = [...points]; //復(fù)制后的數(shù)組用于在洗牌后設(shè)置方塊的當(dāng)前坐標(biāo) shuffle(shuffledPoints);//洗牌 for (var i = 0; i < points.length; i++) { const point = points[i]; //創(chuàng)建方塊對(duì)象 var b = { left: point.left, top: point.top, curLeft: shuffledPoints[i].left, curTop: shuffledPoints[i].top, dom: document.createElement("div"), update() { this.dom.style.transition = "all .5s"; this.dom.style.left = this.curLeft + "px"; this.dom.style.top = this.curTop + "px"; }, isCorrect() { return this.curTop === this.top && this.curLeft === this.left; }, isEmpty: i === points.length - 1 //是否應(yīng)該是空白方塊 } b.dom.style.width = computed.w + "px"; b.dom.style.height = computed.h + "px"; b.dom.style.position = "absolute"; b.dom.style.border = "1px solid #fff"; b.dom.style.boxSizing = "border-box"; b.dom.style.background = `url("${config.img}")`; b.dom.style.cursor = "pointer"; b.dom.style.backgroundPosition = `-${b.left}px -${b.top}px`; b.dom.block = b; b.dom.onclick = function () { switchBlock(this.block); } b.update(); blocks.push(b); } } /** * 生成游戲 */ function generateGame() { config.gameDom.style.width = config.width + "px"; config.gameDom.style.height = config.height + "px"; config.gameDom.style.border = "2px solid #8c8c8c"; config.gameDom.innerHTML = ""; //清空區(qū)域 for (const item of blocks) { if (!item.isEmpty) { config.gameDom.appendChild(item.dom); } } } /** * 獲得所有方塊的可取到的坐標(biāo)數(shù)組 */ function getPointsArray() { var arr = []; for (var i = 0; i < computed.num; i++) { arr.push({ left: (i % config.col) * computed.w, top: parseInt(i / config.col) * computed.h }); } return arr; } /** * 將某個(gè)block對(duì)象的坐標(biāo),與空坐標(biāo)交換 * @param {*} block */ function switchBlock(block) { //找到空坐標(biāo) var emptyBlock = blocks.find(b=>b.isEmpty); //判斷是否相鄰 if(Math.abs(block.curLeft - emptyBlock.curLeft) + Math.abs(block.curTop - emptyBlock.curTop) !== computed.w){ return; } //交換 var bLeft = block.curLeft; var bTop = block.curTop; block.curLeft = emptyBlock.curLeft; block.curTop = emptyBlock.curTop; emptyBlock.curLeft = bLeft; emptyBlock.curTop = bTop; block.update(); emptyBlock.update(); if(isWin()){ setTimeout(() => { alert("游戲勝利") }, 500); } } /** * 數(shù)組洗牌 * @param {*} arr */ function shuffle(arr) { for (var i = 0; i < arr.length - 1; i++) { var targetIndex = getRandom(0, arr.length - 1); var temp = arr[i]; arr[i] = arr[targetIndex]; arr[targetIndex] = temp; } } function getRandom(min, max) { var dec = max - min; return Math.floor(Math.random() * dec + min); } /** * 游戲是否勝利 */ function isWin() { for (const b of blocks) { if (!b.isCorrect()) { return false; } } return true; } setBlocks(); generateGame();
總結(jié)
以上所述是小編給大家介紹的基于JS實(shí)現(xiàn)簡(jiǎn)單滑塊拼圖游戲,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
- JS快速實(shí)現(xiàn)移動(dòng)端拼圖游戲
- JS 拼圖游戲 面向?qū)ο?,注釋完整?/a>
- js+html5實(shí)現(xiàn)可在手機(jī)上玩的拼圖游戲
- JS實(shí)現(xiàn)拼圖游戲
- jQuery+vue.js實(shí)現(xiàn)的九宮格拼圖游戲完整實(shí)例【附源碼下載】
- 基于javascript制作經(jīng)典傳統(tǒng)的拼圖游戲
- 基于Vue.js實(shí)現(xiàn)數(shù)字拼圖游戲
- 利用原生的JavaScript實(shí)現(xiàn)簡(jiǎn)單拼圖游戲
- javascript結(jié)合Flexbox簡(jiǎn)單實(shí)現(xiàn)滑動(dòng)拼圖游戲
- 使用js編寫(xiě)實(shí)現(xiàn)拼圖游戲
相關(guān)文章
[js高手之路]單例模式實(shí)現(xiàn)模態(tài)框的示例
下面小編就為大家?guī)?lái)一篇[js高手之路]單例模式實(shí)現(xiàn)模態(tài)框的示例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09- curring的概念將函數(shù)式編程的概念和默認(rèn)參數(shù)以及可變參數(shù)結(jié)合在一起.一個(gè)帶n個(gè)參數(shù),curried的函數(shù)固化第一個(gè)參數(shù)為固定參數(shù),并返回另一個(gè)帶n-1個(gè)參數(shù)的函數(shù)對(duì)象,分別類(lèi)似于LISP的原始函數(shù)car和cdr的行為。currying能泛化為偏函數(shù)應(yīng)用(partial function application, PFA),p 這種函數(shù)將任意數(shù)量(順序)的參數(shù)的函數(shù)轉(zhuǎn)化為另一個(gè)帶剩余參數(shù)的函數(shù)對(duì)象2012-02-02
Javascript?中AJAX的圖書(shū)管理代碼實(shí)例詳解
這篇文章主要為大家詳細(xì)介紹了AJAX的圖書(shū)管理代碼實(shí)例,使用數(shù)據(jù)庫(kù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02js調(diào)用后臺(tái)、后臺(tái)調(diào)用前臺(tái)等方法總結(jié)
這篇文章主要對(duì)js調(diào)用后臺(tái),后臺(tái)調(diào)用前臺(tái)等方法做個(gè)總結(jié),需要的朋友可以參考下2014-04-04JS中超越現(xiàn)實(shí)的匿名函數(shù)用法實(shí)例分析
這篇文章主要介紹了JS中超越現(xiàn)實(shí)的匿名函數(shù)用法,結(jié)合實(shí)例形式分析了javascript匿名函數(shù)定義、用法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2019-06-06javascript在事件監(jiān)聽(tīng)方面的兼容性小結(jié)
javascript 在事件監(jiān)聽(tīng)方面的兼容性總結(jié),注意是由于多個(gè)瀏覽器的不一致,導(dǎo)致大家在js書(shū)寫(xiě)時(shí)需要考慮多個(gè)瀏覽器的兼容性。2010-04-04基于jquery實(shí)現(xiàn)導(dǎo)航菜單高亮顯示(兩種方法)
本篇文章是基于jquery實(shí)現(xiàn)導(dǎo)航菜單高亮顯示,當(dāng)點(diǎn)擊不同導(dǎo)航菜單實(shí)現(xiàn)當(dāng)前點(diǎn)擊的菜單是高亮的,有需要的朋友可以關(guān)注下本文2015-08-08JavaScript實(shí)現(xiàn)數(shù)組降維詳解
大家都知道將多維數(shù)組(尤其是二維數(shù)組)轉(zhuǎn)化為一維數(shù)組是業(yè)務(wù)開(kāi)發(fā)中的常用邏輯,除了使用樸素的循環(huán)轉(zhuǎn)換以外,我們還可以利用Javascript的語(yǔ)言特性和數(shù)據(jù)結(jié)構(gòu)的思想實(shí)現(xiàn)更為簡(jiǎn)潔優(yōu)雅的轉(zhuǎn)換。下面跟著小編一起來(lái)學(xué)習(xí)學(xué)習(xí)關(guān)于JavaScript如何實(shí)現(xiàn)數(shù)組降維吧。2017-01-01bootstrap-table組合表頭的實(shí)現(xiàn)方法
本篇文章主要介紹了bootstrap-table組合表頭的實(shí)現(xiàn)方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-09-09