欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于JS實現(xiàn)簡單滑塊拼圖游戲

 更新時間:2019年10月12日 08:41:55   作者:凌寒舞_宇  
本文通過實例代碼給大家介紹了JS實現(xià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)過計算的一些數(shù)據(jù)
var computed = {
  num: config.col * config.row, //方塊數(shù)量
  w: config.width / config.col, //每個小方塊的寬度
  h: config.height / config.row //每個小方塊的高度
}
//方塊對象的數(shù)組,每個對象中記錄了方塊的正確坐標、當前坐標、dom元素、以及一些實用方法
var blocks;
/**
 * 為全局變量blocks賦值
 */
function setBlocks() {
  blocks = [];
  var points = getPointsArray(); //該數(shù)組用于設置每個方塊的正確坐標
  var shuffledPoints = [...points]; //復制后的數(shù)組用于在洗牌后設置方塊的當前坐標
  shuffle(shuffledPoints);//洗牌
  for (var i = 0; i < points.length; i++) {
    const point = points[i];
    //創(chuàng)建方塊對象
    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 //是否應該是空白方塊
    }
    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);
    }
  }
}
/**
 * 獲得所有方塊的可取到的坐標數(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;
}

/**
 * 將某個block對象的坐標,與空坐標交換
 * @param {*} block 
 */
function switchBlock(block) {
  //找到空坐標
  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();

總結

以上所述是小編給大家介紹的基于JS實現(xiàn)簡單滑塊拼圖游戲,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

相關文章

  • [js高手之路]單例模式實現(xiàn)模態(tài)框的示例

    [js高手之路]單例模式實現(xiàn)模態(tài)框的示例

    下面小編就為大家?guī)硪黄猍js高手之路]單例模式實現(xiàn)模態(tài)框的示例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • javascript的currying函數(shù)介紹

    javascript的currying函數(shù)介紹

    curring的概念將函數(shù)式編程的概念和默認參數(shù)以及可變參數(shù)結合在一起.一個帶n個參數(shù),curried的函數(shù)固化第一個參數(shù)為固定參數(shù),并返回另一個帶n-1個參數(shù)的函數(shù)對象,分別類似于LISP的原始函數(shù)car和cdr的行為。currying能泛化為偏函數(shù)應用(partial function application, PFA),p 這種函數(shù)將任意數(shù)量(順序)的參數(shù)的函數(shù)轉化為另一個帶剩余參數(shù)的函數(shù)對象
    2012-02-02
  • Javascript?中AJAX的圖書管理代碼實例詳解

    Javascript?中AJAX的圖書管理代碼實例詳解

    這篇文章主要為大家詳細介紹了AJAX的圖書管理代碼實例,使用數(shù)據(jù)庫,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • js調用后臺、后臺調用前臺等方法總結

    js調用后臺、后臺調用前臺等方法總結

    這篇文章主要對js調用后臺,后臺調用前臺等方法做個總結,需要的朋友可以參考下
    2014-04-04
  • JS中超越現(xiàn)實的匿名函數(shù)用法實例分析

    JS中超越現(xiàn)實的匿名函數(shù)用法實例分析

    這篇文章主要介紹了JS中超越現(xiàn)實的匿名函數(shù)用法,結合實例形式分析了javascript匿名函數(shù)定義、用法及相關操作注意事項,需要的朋友可以參考下
    2019-06-06
  • 以fetch為例詳解如何消除js異步的傳染性

    以fetch為例詳解如何消除js異步的傳染性

    這篇文章主要為大家介紹了以fetch為例詳解如何消除js異步的傳染性示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12
  • javascript在事件監(jiān)聽方面的兼容性小結

    javascript在事件監(jiān)聽方面的兼容性小結

    javascript 在事件監(jiān)聽方面的兼容性總結,注意是由于多個瀏覽器的不一致,導致大家在js書寫時需要考慮多個瀏覽器的兼容性。
    2010-04-04
  • 基于jquery實現(xiàn)導航菜單高亮顯示(兩種方法)

    基于jquery實現(xiàn)導航菜單高亮顯示(兩種方法)

    本篇文章是基于jquery實現(xiàn)導航菜單高亮顯示,當點擊不同導航菜單實現(xiàn)當前點擊的菜單是高亮的,有需要的朋友可以關注下本文
    2015-08-08
  • JavaScript實現(xiàn)數(shù)組降維詳解

    JavaScript實現(xiàn)數(shù)組降維詳解

    大家都知道將多維數(shù)組(尤其是二維數(shù)組)轉化為一維數(shù)組是業(yè)務開發(fā)中的常用邏輯,除了使用樸素的循環(huán)轉換以外,我們還可以利用Javascript的語言特性和數(shù)據(jù)結構的思想實現(xiàn)更為簡潔優(yōu)雅的轉換。下面跟著小編一起來學習學習關于JavaScript如何實現(xiàn)數(shù)組降維吧。
    2017-01-01
  • bootstrap-table組合表頭的實現(xiàn)方法

    bootstrap-table組合表頭的實現(xiàn)方法

    本篇文章主要介紹了bootstrap-table組合表頭的實現(xiàn)方法,非常具有實用價值,需要的朋友可以參考下
    2017-09-09

最新評論