返回課程

建立一個可擴充的計算器

重要性:5

建立一個建構函式 Calculator,用來建立「可擴充」的計算器物件。

這個任務包含兩個部分。

  1. 首先,實作 calculate(str) 方法,它會接收一個字串,例如 "1 + 2",格式為「數字 運算子 數字」(以空白分隔),並傳回結果。應該要能理解加號 + 和減號 -

    使用範例

    let calc = new Calculator;
    
    alert( calc.calculate("3 + 7") ); // 10
  2. 接著,新增 addMethod(name, func) 方法,用來教導計算器新的運算。它會接收運算子 name 和實作運算的兩個引數函式 func(a,b)

    例如,我們加入乘法 *、除法 / 和次方 **

    let powerCalc = new Calculator;
    powerCalc.addMethod("*", (a, b) => a * b);
    powerCalc.addMethod("/", (a, b) => a / b);
    powerCalc.addMethod("**", (a, b) => a ** b);
    
    let result = powerCalc.calculate("2 ** 3");
    alert( result ); // 8
  • 此任務中沒有括號或複雜的表達式。
  • 數字和運算子之間僅以一個空格分隔。
  • 如果你想加入,可能會有一些錯誤處理。

開啟一個包含測試的沙盒。

  • 請注意方法是如何儲存的。它們僅加入 this.methods 屬性。
  • 所有測試和數字轉換都在 calculate 方法中完成。未來可能會擴充以支援更複雜的表達式。
function Calculator() {

  this.methods = {
    "-": (a, b) => a - b,
    "+": (a, b) => a + b
  };

  this.calculate = function(str) {

    let split = str.split(' '),
      a = +split[0],
      op = split[1],
      b = +split[2];

    if (!this.methods[op] || isNaN(a) || isNaN(b)) {
      return NaN;
    }

    return this.methods[op](a, b);
  };

  this.addMethod = function(name, func) {
    this.methods[name] = func;
  };
}

在沙盒中開啟包含測試的解決方案。