为什么等式的值最后没有定义?
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);
});
我用 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);
});