为什么等式的值最后没有定义?

Why value of equation has undefined at the end?

我用 JS 和 jQuery 编写了简单的计算器,但遇到了奇怪的行为。在下面的代码中,您会看到变量 equation,它保存计算器上按下的每个数字。然后我使用 eval() 来评估。

问题是,equation 变量的值是你所期望的,但最后有 undefined,无法计算为什么。

整个项目在这里:http://codepen.io/ketus/full/XmYRoV/

提前感谢您的帮助!

PS.: 我知道关于 eval() 的普遍看法。它仅用于测试,因此我可以移动。在解决 undefined.

的问题后,我将实施自己的解决方案

$(document).ready(function() {  
  
  var equation = '';
  var input = $('h2[data-value]');  
  var info = $('#info');
  //get keys
  var keys = $('.key').filter(function() {
    return $(this).data('key');
  }).get();  
  
  //get operators
  var operators = $('.operator').filter(function() {
    return $(this).data('operator');
  }).get();    
  
  //Clearing input
  $('.clear').click(function(){
    equation = '';
    input.html('');
    info.html('');
  });  
  
  //user press keys, check if correct after each click 
  $('.key').click(function(){
    equation += $(this).data('key');  
    //evaluateEquation();
    input.html(equation);    
  });   
  
  //showing result
  $('a[data-calc]').click(function(){
    input.html(eval(equation.toString()));
  }); 
  
  // rules for equation to be correct
  //function evaluateEquation()  {    
  //}
  
  function calculate(){    
    if(equation.length > 0){    
      return eval(equation);
    } else { 
      info.html('Enter something!');
      return '';
    } 
  }
  
});

主要问题是用户按下事件处理程序。如果按下 =,则不应附加 data('key')。例如,您可以像这样排除此按钮:

  //user press keys, check if correct after each click 
  $('.key:not([data-calc])').click(function(){
    equation += $(this).data('key');  
    input.html(equation);    
  });   

演示: http://codepen.io/anon/pen/qOKwOE?editors=101