草庐IT

javascript - Angular 内存游戏

coder 2025-01-15 原文

我正在重制 memory game熟悉controllerAs View Syntax .我已将问题缩小到检查功能;但我可能是错的。检查函数将 card 作为参数传递,但是当我使用 console.log(card) 时,card 没有值,而 card 应该具有数组平假名或可选字母的值。

   (function() {

// constant variables 
var constants = new (function() {
    var rows = 3;
    var columns = 6;
    var numMatches = (rows * columns) / 2;
    this.getRows = function() { return rows; };
    this.getColumns = function() { return columns; };
    this.getNumMatches = function() { return numMatches; };
})();

// Global Variables
var currentSessionOpen = false;
var previousCard = null;
var numPairs = 0;

// this function creates deck of cards that returns an object of cards 
// to the caller
function createDeck() {
    var rows = constants.getRows();
    var cols = constants.getColumns();
    var key = createRandom();
    var deck = {};
    deck.rows = [];

    // create each row
    for(var i = 0; i < rows; i++) {
        var row = {};
        row.cards = [];

        // create each card in the row
        for (var j = 0; j < cols; j++) {
            var card = {};
            card.isFaceUp = false;
            card.item = key.pop();
            row.cards.push(card);
        }
        deck.rows.push(row);
    }
    return deck;
}

// used to remove something form an array by index
function removeByIndex(arr, index) {
    arr.splice(index, 1);
}

function insertByIndex(arr, index, item) {
    arr.splice(index, 0, item);
}

// creates a random array of items that contain matches
// for example: [1, 5, 6, 5, 1, 6]
function createRandom() {
    var matches = constants.getNumMatches();
    var pool = [];
    var answers = [];
    var letters = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I'
                    , 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R'
                    , 'S', 'T', 'U', 'W', 'X', 'Y', 'Z'];

    var hiragana = ['あ', 'い', 'う', 'え', 'お', 'か', 'が', 'き'
                    , 'ぎ', 'く', 'ぐ', 'け', 'げ', 'こ', 'ご', 'さ'
                    , 'ざ', 'し', 'じ', 'す', 'ず', 'せ', 'ぜ', 'そ'
                    , 'ぞ', 'た', 'だ', 'ち', 'ぢ', 'つ', 'づ', 'て'
                    , 'で', 'と', 'ど', 'な', 'に', 'ぬ', 'ね', 'の'
                    , 'は', 'ば', 'ぱ', 'ひ', 'び', 'ぴ', 'ふ', 'ぶ'
                    , 'ぷ', 'へ', 'べ', 'ぺ', 'ほ', 'ぼ', 'ぽ', 'ま'
                    , 'み', 'む', 'め', 'も', 'や', 'ゆ', 'よ', 'ら'
                    , 'り', 'る', 'れ', 'ろ', 'わ', 'を', 'ん'];
    // set what kind of item to display
    var items = hiragana;

    // create the arrays for random numbers and item holder
    for (var i = 0; i < matches * 2; i++) {
        pool.push(i); // random numbers
    }

    // generate an array with the random items
    for (var n = 0; n < matches; n++) {
        // grab random letter from array and remove that letter from the
        // original array
        var randLetter = Math.floor((Math.random() * items.length));
        var letter = items[randLetter];
        removeByIndex(items, randLetter);
        // generate two random placements for each item
        var randPool = Math.floor((Math.random() * pool.length));

        // remove the placeholder from answers and insert the letter into 
        // random slot
        insertByIndex(answers, pool[randPool], letter);

        // remove random number from pool
        removeByIndex(pool, randPool);

        // redo this process for the second placement
        randPool = Math.floor((Math.random() * pool.length));
        insertByIndex(answers, pool[randPool], letter);

        // remove rand number from pool
        removeByIndex(pool, randPool);
    }
    return answers;
} 

angular.module('cards', ['ngAnimate']);

  angular
    .module('cards')
    .controller('CardController', CardController);

  function CardController($timeout) {

    /* jshint validthis: true */
    var vm = this;
    vm.deck = createDeck();
    vm.isGuarding = true;
    vm.inGame = false;

    function check(card) {
        if (currentSessionOpen && previousCard != card && previousCard.item == card.item && !card.isFaceUp) {
          card.isFaceUp = true;
            console.log(card.isFaceUp);
          previousCard = null;
          currentSessionOpen = false;
          numPairs++;
        } else if (currentSessionOpen && previousCard != card && previousCard.item != card.item && !card.isFaceUp) {
          vm.isGuarding = true;
          vm.card.isFaceUp = true;
            console.log(vm.card.isFaceUp)
          currentSessionOpen = false;
          $timeout(function() {
            previousCard.isFaceUp = card.isFaceUp = false;
            previousCard = null;
            vm.isGuarding = vm.timeLimit ? false : true;
          }, 1000);
        } else {
          card.isFaceUp = true;
          currentSessionOpen = true;
          previousCard = card;
        }

        if (numPairs == constants.getNumMatches()) {
          vm.stopTimer();
        }
      } //end of check()

    // for the timer
    vm.timeLimit = 60000;
    vm.isCritical = false;

    var timer = null;

    // start the timer as soon as the player presses start
    vm.start = function() {
        // I need to fix this redundancy. I initially did not create this
        // game with a start button.
        vm.deck = createDeck();
        // set the time of 1 minutes and remove the cards guard
        vm.timeLimit = 60000;
        vm.isGuarding = false;
        vm.inGame = true;

        (vm.startTimer = function() {
          vm.timeLimit -= 1000;
          vm.isCritical = vm.timeLimit <= 10000 ? true : false;

          timer = $timeout(vm.startTimer, 1000);
          if (vm.timeLimit === 0) {
            vm.stopTimer();
            vm.isGuarding = true;
          }
        })();
      }
      // function to stop the timer
    vm.stopTimer = function() {
      $timeout.cancel(timer);
      vm.inGame = false;
      previousCard = null;
      currentSessionOpen = false;
      numPairs = 0;
    }
  } //end CardController

})();


<!doctype html>
<html ng-app="cards">
<head>
   <meta charset="utf-8">
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.5.7/angular.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.4.0/angular-animate.js"></script>
    <script src="https://ajax.googleapis.com/ajax/libs/angular_material/1.1.1/angular-material.js"></script>
    <link rel="stylesheet" href="cards.css">
</head>

<body>
    <div class="cntr" ng-controller="CardController as cards">
        <div class="timer" ng-class="{critical:cards.isCritical}">
            {{cards.timeLimit | date: 'm:ss'}}  
        </div>
        <table class="table-top">
            <tr ng-repeat="row in cards.deck.rows">
                <td ng-repeat="card in row.cards">
                    <div class="card_container {{!card.isFaceUp ? '' : 'flip'}}" ng-click="cards.isGuarding || check(card)" >
                        <div class="card shadow">
                            <div class="front face"></div>
                            <div class="back face text-center pagination-center">
                                <p> {{card.item}} </p>
                            </div>
                        </div>
                    </div>
                </td>
            </tr>
        </table>
        <div class="startbtn">
            <button type="button" class="btn btn-default btn-lg" ng-disabled="cards.inGame == true" ng-click="cards.start()">Start</button>
        </div>
    </div>
    <script type="text/javascript" src="cards.js"></script>
</body>
</html>

最佳答案

您需要让您的检查功能对 View 可见。

vm.check = check;

同样在调用函数时,因为你正在使用

ng-controller="CardController as cards"

您需要从 View 中将该函数调用为 cards.check()。

关于javascript - Angular 内存游戏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39845832/

有关javascript - Angular 内存游戏的更多相关文章

  1. ruby-on-rails - Ruby net/ldap 模块中的内存泄漏 - 2

    作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代

  2. ruby-on-rails - Ruby 中的内存模型 - 2

    ruby如何管理内存。例如:如果我们在执行过程中采用C程序,则以下是内存模型。类似于这个ruby如何处理内存。C:__________________|||stack|||------------------||||------------------|||||Heap|||||__________________|||data|__________________|text|__________________Ruby:? 最佳答案 Ruby中没有“内存”这样的东西。Class#allocate分配一个对象并返回该对象。这就是程序

  3. 键删除后 ruby​​ 哈希内存泄漏 - 2

    你好,我无法成功如何在散列中删除key后释放内存。当我从哈希中删除键时,内存不会释放,也不会在手动调用GC.start后释放。当从Hash中删除键并且这些对象在某处泄漏时,这是预期的行为还是GC不释放内存?如何在Ruby中删除Hash中的键并在内存中取消分配它?例子:irb(main):001:0>`ps-orss=-p#{Process.pid}`.to_i=>4748irb(main):002:0>a={}=>{}irb(main):003:0>1000000.times{|i|a[i]="test#{i}"}=>1000000irb(main):004:0>`ps-orss=-p

  4. ruby - 我需要从 facebook 游戏中抓取数据——使用 ruby - 2

    修改(澄清问题)我已经花了几天时间试图弄清楚如何从Facebook游戏中抓取特定信息;但是,我遇到了一堵又一堵砖墙。据我所知,主要问题如下。我可以使用Chrome的检查元素工具手动查找我需要的html-它似乎位于iframe中。但是,当我尝试抓取该iframe时,它​​是空的(属性除外):如果我使用浏览器的“查看页面源代码”工具,这与我看到的输出相同。我不明白为什么我看不到iframe中的数据。答案不是它是由AJAX之后添加的。(我知道这既是因为“查看页面源代码”可以读取Ajax添加的数据,也是因为我有b/c我一直等到我可以看到数据页面之后才抓取它,但它仍然不存在)。发生这种情况是因为

  5. ruby-on-rails - 使用 javascript 更改数据方法不会更改 ajax 调用用户的什么方法? - 2

    我遇到了一个非常奇怪的问题,我很难解决。在我看来,我有一个与data-remote="true"和data-method="delete"的链接。当我单击该链接时,我可以看到对我的Rails服务器的DELETE请求。返回的JS代码会更改此链接的属性,其中包括href和data-method。再次单击此链接后,我的服务器收到了对新href的请求,但使用的是旧的data-method,即使我已将其从DELETE到POST(它仍然发送一个DELETE请求)。但是,如果我刷新页面,HTML与"new"HTML相同(随返回的JS发生变化),但它实际上发送了正确的请求类型。这就是这个问题令我困惑的

  6. ruby-on-rails - HTTParty 的内存问题和下载大文件 - 2

    这会导致Ruby出现内存问题吗?我知道如果大小超过10KB,Open-URI会写入TempFile。但是HTTParty会在写入TempFile之前尝试将整个PDF保存到内存吗?src=Tempfile.new("file.pdf")src.binmodesrc.writeHTTParty.get("large_file.pdf").parsed_response 最佳答案 您可以使用Net::HTTP。参见thedocumentation(特别是标题为“流媒体响应机构”的部分)。这是文档中的示例:uri=URI('http://e

  7. python - Ruby 或 Python 的 3d 游戏引擎? - 2

    关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于StackOverflow来说是偏离主题的,因为它们往往会吸引自以为是的答案和垃圾邮件。相反,describetheproblem以及迄今为止为解决该问题所做的工作。关闭9年前。Improvethisquestion是否有适用于这些的3d游戏引擎?

  8. ruby - 在 Mechanize 中使用 JavaScript 单击链接 - 2

    我有这个:AccountSummary我想单击该链接,但在使用link_to时出现错误。我试过:bot.click(page.link_with(:href=>/menu_home/))bot.click(page.link_with(:class=>'top_level_active'))bot.click(page.link_with(:href=>/AccountSummary/))我得到的错误是:NoMethodError:nil:NilClass的未定义方法“[]” 最佳答案 那是一个javascript链接。Mechan

  9. javascript - jQuery 的 jquery-1.10.2.min.map 正在触发 404(未找到) - 2

    我看到有关未找到文件min.map的错误消息:GETjQuery'sjquery-1.10.2.min.mapistriggeringa404(NotFound)截图这是从哪里来的? 最佳答案 如果ChromeDevTools报告.map文件的404(可能是jquery-1.10.2.min.map、jquery.min.map或jquery-2.0.3.min.map,但任何事情都可能发生)首先要知道的是,这仅在使用DevTools时才会请求。您的用户不会遇到此404。现在您可以修复此问题或禁用sourcemap功能。修复:获取文

  10. ruby-on-rails - 内存中具有相同 ID 的更多对象? - 2

    在部署在heroku上的Rails应用程序(v:3.1)中,我在内存中获得了更多具有相同ID的对象。我的heroku控制台日志:>>Project.find_all_by_id(92).size=>2>>ActiveRecord::Base.connection.execute('select*fromprojectswhereid=92').to_a.size=>1这怎么可能?可能是什么问题? 最佳答案 解决方案根据您的SQL查询,您的数据库中显然没有重复条目。也许您的类项目中的size或length方法已被覆盖。我试过find_

随机推荐