0

我已经$display在 cacheDom 函数中兑现了,但是当我尝试在 updateResult 函数中使用它时它不起作用this.$display.text(temp).apply(this);。我认为这与范围规则有关,我一定错过了一些东西。任何帮助将不胜感激。

$(document).ready(function() {
  (function() {
    var current = "", result = 0;
    var calculator = {
      init: function() {
        this.cacheDom();
        this.render();
        this.bindEvents();
      },
      cacheDom: function() {
        this.$button = $(".button p, .zero p");
        this.$display = $("#display p");
      },
      bindEvents: function() {
        this.$button.on("click", this.updateResult);
      },
      updateResult: function() {
        var temp = $(this).text();
        if (parseInt(temp) > 0 == false) {
          if (temp == "÷") {
            current += "/";
            this.$display.text(temp).apply(this);
          } else if (temp == "×") {
            current += "*";
            $("#display p").text(temp);
          } else if (temp == "-") {
            current += temp;
            $("#display p").text(temp);
          } else if (temp == "+") {
            current += temp;
            $("#display p").text(temp);
          } else if (temp == "=") {
            current = eval(current);
            $("#display p").text(current);
          } else if (temp == "C") {
            current = "";
            temp = "";
            result = 0;
            $("#display p").text(result);
          } else if (temp == "%") {
            current = current / 100;
            $("#display p").text(current);
          } else if (temp == "√") {
            $("#display p").text(Math.sqrt(parseInt(current[current.length - 1])));
            var sqrt = Math.sqrt(parseInt(current[current.length - 1]));
            current = current.substring(0, current.length - 1)
            current += sqrt;
          }
        } else {
          $("#display p").text(temp);
          current += temp;
        }
        console.log(current);
      },
      render: function() {

      },
    };
    calculator.init();
  })()
});
4

0 回答 0